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Method and Apparatus for Providing Automation 
to an Internet Navigation Application 

By inventor (s) Sam Khavari and Tim Armandpour 

5 

Field of the Invention 

10 The present invention is in the field of Internet navigation including 

various communication and connection technologies and pertains more 
particularly to methods and apparatus, including software, for providing 
automated functionality to a navigation application. 

15 Cross-Reference to Related Documents 

The present invention is a continuation in part (CIP) to a patent 
application docket number P3925, serial No. 09/629,492, filed 7/3 1/2000 

20 entitled, ''Software Bundle for Providing Automated Functionality to a 
WEB-Browser, which is a (CIP) to a patent application docket number 
P3919, serial No. 09/550,348, filed 4/14/2000, entitled "Method and 
Apparatus for Providing Auto-Registration and Service Access to Internet 
Sites for Internet Portal Subscribers", which is a CIP to patent application 

25 docket No. P3918, serial No. 09/532,647, filed 3/22/2000 entitled "Method 
and Apparatus for Retrieving Information From Semi-Structured, WEB- 
Based Data Sources", which is a CIP of a patent application docket No. 
P3902, S/N 09/323,598 entitled "Method and Apparatus for Obtaining 
and Presenting WEB Summaries to Users" filed on 06/01/99, which is a 

30 CIP to a patent application docket No. P3901, S/N 09/208,740 entitled 
"Method and Apparatus for Providing and Maintaining a User- 
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Interactive Portal System Accessible via Internet or other Switched- 
Packet-Network" filed on 12/08/98, all disclosures of which are 
incorporated herein in their entirety herein by reference. 

5 

Background of the Invention 

The information network known as the World Wide Web (WWW), 
which is a subset of the well-known Internet, is arguably the most complete 

10 source of publicly accessible information available. Anyone with a suitable 
Internet appliance such as a personal computer with a standard Internet 
connection may access (go on-line) and navigate to information pages 
(termed web pages) stored on Internet-connected servers for the purpose of 
garnering information and initiating transactions with hosts of such servers 

15 and pages. 

Many companies offer various subscription services accessible via the 
Internet. For example, many people now do their banking, stock trading, 
shopping, and so forth from the comfort of their own homes via Internet 
access. Typically, a user, through subscription, has access to personalized 

20 and secure WEB pages for such functions. By typing in a user name and a 
password or other personal identification code, a user may obtain 
information, initiate transactions, buy stock, and accomplish a myriad of 
other tasks. 

One problem that is encountered by an individual who has several or 
25 many such subscriptions to Internet-brokered services is that there are 

invariably many passwords and/or log-in codes to be used. Often a same 
password or code cannot be used for every service, as the password or code 
may already be taken by another user. A user may not wish to supply a code 
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unique to the user such as perhaps a social security number because of 
security issues, including quality of security that may vary from service to 
service. Additionally, many users at their own volition may choose different 
passwords for different sites so as to have increased security, which in fact 

5 also increases the number of passwords a user may have. 

Another issue that can plague a user who has many passworded 
subscriptions is the fact that they must bookmark many WEB pages in a 
computer cache so that they may quickly find and access the various 
services. For example, in order to reserve and pay for airline travel, a user 

10 must connect to the Internet, go to his/her book-marks file and select an 
airline page. The user then has to enter a user name and password, and 
follow on-screen instructions once the page is delivered. If the user wishes 
to purchase tickets from the WEB site, and wishes to transfer funds from an 
on-line banking service, the user must also look for and select the personal 

15 bank or account page to initiate a funds transfer for the tickets. Different 

user names and passwords may be required to access these other pages, and 
things get quite complicated. 

Although this preceding example is merely exemplary, it is generally 
known that much work related to finding WEB pages, logging in with 

20 passwords, and the like is required to successfully do business on the WEB. 
A service known to the inventor and described in disclosure 
referenced by S/N 09/208,740 listed under the cross-reference to related 
documents section provides a WEB service that allows a user to store all of 
his password protected pages in one location such that browsing and 

25 garnering information from them is much simplified. A feature of the above 
service allows a user to program certain tasks into the system such that 
requested tasks are executed by an agent (software) based on user 
instruction. The service stores user password and log-in information and 
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uses the information to log-in to the user's sites, thus enabling the user to 
navigate without having to manually input log-in or password codes to gain 
access to the links. 

The above-described service uses a server to present a user- 

5 personalized application that may be displayed as an interactive home page 
that contains all of his listed sites (hyperlinks) for easy navigation. The 
application lists the user's URLs in the form of hyperlinks such that a user 
may click on a hyperlink and navigate to the page wherein login, if required, 
is automatic, and transparent to the user. 

10 The application described above also includes a software agent that 

may be programmed to perform scheduled tasks for the user including 
returning specific summaries and updates about user-account pages. A 
search function is provided and adapted to cooperate with the software 
agent to search user-entered URLs for specific content if such pages are 

15 cached somewhere in their presentable form such as at the portal server, or 
on the client's machine. 

A further enhancement to the system described above is known to 
the inventor and described in the disclosure of application S/N 09/323,598 
also listed under the cross-reference section. The described enhancement 

20 consists of a means for obtaining information from WEB-based sources 

using a site-navigation script, a field template, and a means for parsing data. 
The navigation script follows site logic of a target WEB site containing the 
data for return to a user. Part of the template includes the description and 
location of the data requested by a user. A parsing engine acts to identify 

25 the new data for retrieval for a user. In this way, WEB summaries may be 
compiled on updated data at user-frequented sites. 

A further enhancement to the above system is known to the inventor 
and disclosed under the patent application listed in the cross-reference 
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section as P3918 and entitled "Method and Apparatus for Retrieving 
Information From Semi-Structured, WEB-Based Data Sources' 9 . 

In the enhancement described above, an Internet search system is 
structured for efficient data retrieval from semi-structured data sources. 

5 Using a text selection and configuration tool, a user is enabled to navigate to 
a WEB-site, or multiple WEB-sites, and pre-select the block areas of 
information that contain data that he or she wishes to be accessed and 
retrieved during future automated data searches. The data type entered by a 
provided data input function is associated with a WEB page block selected, 

10 and upon search implementation the block selected is searched for the data 
type requested, and data found is retrieved to be provided to the user. In a 
preferred embodiment portions of the system are executed on a user station, 
and other portions on a Portal server to which the user may subscribe. In 
this way, a user may have data retrieved from semi-structured sources and 

15 presented in the form of a summary page. 

The Portal system with the above-described enhancements taught in 
the cross-referenced patent applications also features an automatic 
registration service available to users if they want information from a WEB- 
site or service that requires registration. If the WEB pages are new to a 

20 user, and the user has no registration with the WEB site, then through 

agreement, or other convention, the service may be provided access to such 
sites. Such an agreement may be made, for example, if the host of the WEB 
site realizes a possibility of gaining a new customer if the customer likes the 
summary information presented. In disclosure taught thus far, auto 

25 registration is fairly limited to include only sites that are requested by a user 
and whom are cooperative to the procedure. 

It has occurred to the inventor that the functions of auto-registration 
may be expanded to include a plurality of pre-configured WEB-services 
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which are looking for new clients. Such a value-added service may provide 
researched and rated service sites that collectively provide all of the types of 
singular or multiple services that a Portal subscriber may need or desire. 

Such a system is known to the inventor and referenced in the cross- 

5 reference section above. The system, referred to as a navigation sub-system 
provides a software function, which is part of the system as a whole, for 
populating and submitting electronic forms by proxy over a data-packet- 
network. The system comprises a software application running on a system 
of network-connected servers that enables a user, connected in session with 

10 one of the servers, to navigate to a site containing an electronic form and 
obtain data about the site and about the form. The data obtained is used in 
conjunction with data about the user to construct a machine-readable job 
order upon user request that may be executed for the purpose of automatic 
form population and submission to a host sponsoring the site. Upon 

15 acceptance of the submitted form, data used for passwords, log-in codes and 
user-names is returned to a data repository where it is entered along with 
specific site data as a new registered site item for a registering user such that 
future navigation to the site, auto log-in and data return may be performed 
automatically on behalf of the user. 

20 In order to provide fully automated proxy services on behalf of users, 

a software bundle including an auto-control mechanism must be conceived 
and implemented for the purpose of enabling true automation of java-based 
programs executed by a proxy browsing application without the need for 
user intervention. It is an object of the present invention to provide a truly 

25 automated and self-contained navigation system for performing by proxy all 
of the functions that normally require user input to accomplish. 

A software application known to the inventor and described in one of 
the patent applications listed under the Cross-Reference to Related 
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Documents section above, provides a software-bundle for enabling 
automated navigating and task-performance extension on a data network on 
behalf of a user by proxy. The software bundle comprises a browser 
application, for navigating on the network; a set of functional programs for 

5 performing tasks; a set of APIs for integrating the functional programs to the 
browser application and a control application. The control application 
functions to operate the software bundle including, spawning, managing and 
terminating an instance of the browser application and monitoring behavior 
of the browser instance during a navigation sequence. The software-bundle, 

10 including the browser application, functions as a fully automated navigation 
system capable of performing all of the functions of a manual navigation 
system controlled by a user having a data-input system for controlling the 
navigation system. 

It has occurred to the inventor that, independent of the functionality 

15 that the above-described software-bundle provides, a similar function could 
be added to a PC user's desktop wherein navigation to, logging on to a 
specific website, and performing tasks at the site could be automated. Such 
a task could be accomplished with no user interaction after the initial set up. 
In prior art, users operating desktop browsers must perform many input 

20 actions in order to manage network navigation tasks. Moreover, filling in 
electronic forms for authentication, purchasing, registration, and the like 
require still more input action by a user in session. 

What is clearly needed, and provided by the present invention, is a 
method and apparatus for enabling at least a limited capability for 

25 automating a desktop browser application to perform navigation and 

interaction sequences on behalf of a user wherein manual input required by 
the user is significantly reduced, and in some cases, eliminated. 
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Summary of the Invention 



5 In a preferred embodiment of the present invention, a software 

application for enabling creation and execution of an automated browser 
navigation sequence is provided. The software application comprises a 
session recording module for recording parameters associated with a manual 
navigation sequence, a file creation module for converting data of a manual 

10 session into data comprising an executable sequence of instructions for 

conducting an automated navigation sequence, and an application-program- 
interface module for integrating a functional capability with the automated 
navigation sequence. The automated navigation sequence is characterized in 
that a completely automated browser-navigation sequence performed by the 

15 browser application is enabled through execution of the executable 

instruction sequence created from the recorded parameters of the manual 
navigation sequence. 

In a preferred embodiment, the automated browser-navigation 
sequence is executed to run on a data-packet-network, which in a preferred 

20 application is the Internet network. In a preferred aspect, the file-creation 
module includes a function for creating an icon for launching the automated 
browser-navigation sequence. In the same aspect, the sequence of 
instructions also termed an executable instruction file is executable and 
launches a navigation sequence upon activation. In one embodiment, the 

25 executable sequence of instructions is created using Extensible-Markup- 
Language (XML). In still another aspect, the automated-navigation 
sequence enables automation of one or more of form-population, data- 
downloading, media-interaction, data-searching, hyper-linking. In all 
aspects, the application is in one implementation part a browser plug-in, in 
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another implementation a standalone application, both of which contain a 
user-configuration tool. 

The automated navigation-sequence is created, in some 
embodiments, as a result of manual user programming as an alternative 
5 option to recording a manual sequence. In one embodiment, the automated 
navigation-sequence also includes an embedded request for one or more 
proxy services to be performed by a service provider operating on and 
accessible via the Internet network. In this embodiment, the embedded 
request is automatically sent to the service provider during execution and 

10 performance of an automated navigation sequence. The embedded request 
is received by virtue of an opened communication channel established 
between communicating navigation applications while the sending 
application is performing an automated navigation sequence. 

In another aspect of the present invention, a method for creating an 

15 executable instruction for enabling an automated navigation sequence to be 
performed on a data-packet-network using a browser application is 
provided. The method comprises the steps of ,(a) invoking the browser 
application and connecting to the network, (b) invoking and activating a 
session-recording module for recording a manual navigation sequence, (c) 

20 performing a desired manual navigation sequence, the sequence recorded by 
the recording function, (d) activating a stop-record function to define the 
end of the manual sequence and, (e) converting the recorded manual 
sequence into the executable instruction enabling the automated sequence, 
the conversion performed by software. 

25 In a preferred embodiment in step (a), the data-packet-network is the 

Internet network and in step (e), the software converting data from the 
recorded session into the executable instruction prompts a user to name the 
executable instruction and to name an icon created and associated with 
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instruction. In an enhanced embodiment, a step is added for prompting the 
user with a list of options to add proxy services to the executable instruction. 

In a preferred application, the executable instruction is an XML 
template. In one aspect of the method, the executable instruction contains 
data personal to the user. In this aspect, the personal data includes one or a 
combination of user names, passwords, credit card numbers, user location 
information, and Social Security information. In a preferred application, the 
personal data remains encrypted until use. In another embodiment, the 
personal data remains in a secure location and is called into use by a 
navigation sequence executing and having a pointer to the accessed 
information embedded therein. 

Now, for the first time a method and apparatus for enabling at least a 
limited capability for automating a desktop browser application to perform 
navigation and interaction sequences on behalf of a user is provided. The 
method and apparatus is such that manual input required by the user is 
significantly reduced, and in some cases, eliminated. 

Brief Description of the Drawing Figures 

Fig. 1 is an overview of an Internet portal system and network 
according to an embodiment of the present invention. 

Fig. 2 is an exemplary plan view of a personalized Portal home page 
application as it may be seen on a display monitor according to an 
embodiment of the present invention. 

Fig. 3 is a flow diagram illustrating user interaction with the Internet 
portal of fig. 1 . 
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Fig. 4 is a block diagram illustrating a summarization software agent 
and capabilities thereof according to an embodiment of the present invention. 

Fig. 5 is a logical flow chart illustrating an exemplary summarization 
process performed by the software agent of Fig. 4 operating in a user- 
5 defined mode. 

Fig. 6 is a logical flow chart illustrating an exemplary summarization 
process performed by the software agent of Fig. 4 in a User-independent 
smart mode with minimum user input. 

Fig. 7 is a block diagram illustrating a user-interactive template 
10 generation application according to an embodiment of the present invention. 

Fig. 8 is a block diagram illustrating intelligent parsing capability 
according to an embodiment of the present invention. 

Fig. 9 is a flow chart illustrating a semi-structured data retrieval 
process according to an embodiment of the present invention. 
15 Fig. 10 is an overview of a communications network enhanced with 

automatic site registration according to an embodiment of the present 
invention. 

Fig. 1 1 is a block diagram illustrating software architecture of an 
auto-registration suite according to an embodiment of the present invention. 
20 Fig. 12 is a process flow diagram illustrating various process steps 

for auto-registration to a site and receiving data from the site according to an 
embodiment of the present invention. 

Fig. 13 is a block diagram illustrating an overview of application- 
program-interface (API) and control software bundle according to an 
25 embodiment of the present invention. 

Fig. 14 is a block diagram illustrating function of the navigation API 
ofFig. 13. 
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Fig. 15 is a block diagram illustrating function of the statistic- 
collection API of Fig. 13. 

Fig. 16 is a block diagram illustrating function of the search API of 

Fig. 13. 

5 Fig. 17 is a block diagram illustrating function of the utility API of 

Fig. 13. 

Fig. 18 is a block diagram illustrating function of the error-recovery 
API of Fig. 13. 

Fig. 19 is a block diagram illustrating a robot controller according to 
10 an embodiment of the present invention. 

Fig. 20 is a block diagram illustrating a basic automated navigation 
sequence according to an embodiment of the present invention. 

Fig. 21a block diagram illustrating a user-interface engaged in 
display of an interactive icon. 
15 Fig. 21 b is a block diagram illustrating the user-interface of Fig. 21 a 

displaying a Web address. 

Fig. 21 c is a block diagram illustrating the user-interface of Fig. 21a 
displaying a user-login interface. 

Fig. 21 d is a block diagram illustrating the user-interface of Fig. 21a 
20 displaying a Web result. 

Fig. 22 is a block-diagram illustrating a functional relationship 
between an automated browser session and instruction files stored on a 
user's PC according to an embodiment of the present invention. 

Fig. 23 is block diagram illustrating automated navigation software 
25 according to an embodiment of the present invention. 
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Description of the Preferred Embodiments 



According to a preferred embodiment of the present invention, a 
unique Internet portal is provided and adapted to provide unique services to 

5 users who have obtained access via an Internet or other network connection 
from an Internet-capable appliance. Such an interface provides users with a 
method for storing many personal WEB pages and further provides search 
function and certain task-performing functions. The methods and apparatus 
of the present invention are taught in enabling detail below. 

10 Fig. 1 is an overview of an Internet portal system 1 1 and Internet 

network 13 according to an embodiment of the present invention. Portal 
system 1 1, in this embodiment, operates as an ISP in addition to a unique 
network portal, but may, in other embodiments be implemented as a stand- 
alone Internet server. In yet other embodiments the service and apparatus 

15 described herein may also be provided by such as a search and listing service 
(AltaVista™, Yahoo™) or by any other enterprise hosting a WEB- 
connected server. 

Internet 13 is representative of a preferred use of the present 
invention, but should not be considered limiting, as the invention could apply 

20 in other networks and combinations of networks. 

ISP 1 5 in this embodiment comprises a server 3 1, a modem bank 33, 
represented here by a single modem, and a mass storage repository 29 for 
storing digital data. The modem bank is a convenience, as connection to the 
server could be by another type of network link. ISP 15, as is typical in the 

25 art, provides Internet access services for individual subscribers. In addition 
to well-known Internet access services, ISP 15 also provides a unique 
subscription service as an Internet portal for the purpose of storing many 
WEB pages or destinations along with any passwords and or personal codes 
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associated with those pages, in a manner described in more detail below. 
This unique portal service is provided by execution of Portal Software 35, 
which is termed by the inventors the Password-All suite. The software of 
the invention is referred to herein both as the Portal Software, and as the 

5 Password-all software suite. Also, in much of the description below, the 
apparatus of the invention is referred to by the Password- All terminology, 
such as the Password-All Server or Password-All Portal 

ISP 15 is connected to Internet 13 as shown. Other equipment 
known in the art to be present and connected to a network such as Internet 

10 13, for example, IP data routers, data switches, gateway routers, and the 
like, are not illustrated here but may be assumed to be present. Access to 
ISP 15 is through a connection-oriented telephone system as is known in the 
art, or through any other Internet/WEB access connection, such as through a 
cable modem, special network connection (e.g. Tl), ISDN, and so forth. 

15 Such connection is illustrated via access line 19 from Internet appliance 17 
through modem bank 33 . 

In a preferred embodiment a user has access to Internet Password- All 
Portal services by a user name and password as is well known in the art, 
which provides an individualized WEB page to the subscriber. In another 

20 embodiment wherein a user has other individuals that use his or her Internet 
account, then an additional password or code unique to the user may be 
required before access to portal 3 1 is granted. Such personalized Portal 
WEB pages may be stored in repository 29, which may be any convenient 
form of mass storage. 

25 Three Internet servers 23, 25, and 27, are shown in Internet 13, and 

represent Internet servers hosted by various enterprises and subscribed to by 
a user operating appliance 17. For example, server 23 may be a bank server 
wherein interactive on-line banking and account managing may be 
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performed. Server 25 may be an investment server wherein investment 
accounts may be created and managed. Server 27 may be an airline or travel 
server wherein flights may be booked, tickets may be purchased, and so on. 
In this example, all three servers are secure servers requiring user ID and 
5 password for access, but the invention is not necessarily limited to just 
secure services. 

In a preferred embodiment of the present invention a subscribing user 
operating an Internet-capable appliance, such as appliance 17, connects to 
Password- All Portal system 1 1 hosted by ISP 15, and thereby gains access to 

10 a personalized, interactive WEB page, which in turn provides access to any 
one of a number of servers on Internet 13 such as servers 23, 25, and 27, 
without being required to enter additional passwords or codes. In a 
preferred embodiment the software that enables this service is termed 
Password- All by the inventors. Password-All may be considered to be a 

15 software suite executing on the unique server, and in some instances also on 
the user's station (client). Additional interactivity provided by portal 
software 35 allows a connected user to search his listed pages for 
information associated with keywords, text strings, or the like, and allows a 
user to program user-defined tasks involving access and interaction with one 

20 or more Internet-connected servers such as servers 23, 25, and 27 according 
to a pre-defined time schedule. These functions are taught in enabling detail 
below. 

Fig. 2 is an illustration of a personalized portal page as may be seen 
on a display monitor according to an embodiment of the present invention, 
25 provided by Password-All Portal software 35 executing on server 3 1, in 
response to secure access by a subscriber. Page 32 presents an interactive 
listing 34 of user-subscribed or member WEB pages, identified in this 
example by URL, but which may also be identified by any convenient 
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pseudonym, preferably descriptive, along with user name and typically 
encrypted password information for each page. Listed in a first column 
under destination, are exemplary destinations LBC.com, My Bank.com, My 
Stocks.com, My shopping.com, Mortgage.com, and Airline.com. These are 
5 but a few of many exemplary destinations that may be present and listed as 
such on page 33. In order to view additional listings listed but not 
immediately viewable from within application 33, a scroll bar 35 is provided 
and adapted to allow a user to scroll up or down the list to enable viewing as 
is known in the art. 

10 Items listed in list 34 in this example may be considered destinations 

on such as servers 23, 25, and 27 of Fig. 1. Typically the URL associated 
with an item on this list will not take a user to a server, per se, but to a page 
stored on a server. User names and password data associated with each item 
in list 34 are illustrated in respective columns labeled user name, and 

15 password, to the right of the column labeled destination. Each listing, or at 
least a portion of each listing, is a hyperlink invoking, when selected, the 
URL to that destination. In some instances a particular service may have 
more than one associated URL. For example, My Bank.com may have more 
than one URL associated for such as different accounts or businesses 

20 associated also with a single subscriber. In this case there may be a sub- 
listing for different destinations associated with a single higher-level listing. 
This expedient is not shown, but given this teaching the mechanism will be 
apparent to those with skill in the art. 

In some embodiments one page 33 may be shared by more than one 

25 user, such as a husband and wife sharing a common account and 

subscription. An instance of this is illustrated herein with respect to the 
server labeled Mortgage.com wherein both a John and a Jane Doe are listed 
together under the column labeled user name. In another embodiment a 
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network of individuals, perhaps business owners, authorized co-workers, 
investment parties, or the like may share one application. In this way, 
system 1 1 may be adapted for private individuals as well as business uses. 
After gaining access to application 33 which is served via Internet 

5 portal server 3 1 of Fig. 1, a user may scroll, highlight, and select any URL in 
his or her list 34 for the purpose of navigation to that particular destination 
for further interaction. Application 33 already has each password and user 
name listed for each URL. It is not necessary, however, that the password 
and user name be displayed for a user or users. These may well be stored 

10 transparently in a user's profile, and invoked as needed as a user makes 

selections. Therefore, a user is spared the need of entering passwords and 
user names for any destinations enabled by list 34. Of course, each list 34 is 
built, configured and maintained by a subscribing user or users, and an 
editing facility is also provided wherein a user may edit and update listings, 

15 including changing URLs adding and deleting listings, and the like. 

In another aspect of the invention new listings for a user's profile, 
such as a new passthrough to a bank or other enterprise page, may be added 
semi-automatically as follows: Typically, when a user opens a new account 
with an enterprise through interaction with a WEB page hosted by the 

20 enterprise, the user is required to provide certain information, which will 

typically include such as the user's ED, address, e-mail account, and so forth, 
and typically a new user name and password to access the account. In this 
process the user will be interacting with the enterprise's page from his/her 
browser. A Password-All plug-in is provided wherein, after entering the 

25 required information for the new enterprise, the user may activate a pre- 
determined signal (right click, key stroke, etc.), and the Password-All suite 
will then enter a new passthrough in the user's Password. All profile at the 
Password-All Portal server. 
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In a related method for new entries, the enterprise hosting the 
Password-All Portal may, by agreement with other enterprises, provide log- 
in and sign-up services at the Password- All Portal, with most action 
transparent to the user. For example, there may be, at the Password-All 

5 Portal, a selectable browser list of cooperating enterprises, such as banks, 
security services, and the like, and a user having a Password- All Portal 
subscription and profile may select among such cooperating enterprises and 
open new accounts, which will simultaneously and automatically be added to 
the Password-All Portal page for the user and to the server hosted by the 

10 cooperating enterprise. There may be some interactivity required for 

different accounts, but in the main, much information from the user's profile 
may be used directly without being re-entered. 

The inventors have anticipated that many potential users may well be 
suspicious of providing passwords and user names to an enterprise hosting a 

15 Password-All Portal Server executing a service like Password-All according 
to embodiments of the present invention. To accommodate this problem, in 
preferred embodiments, it is not necessary that the user provide the cleartext 
password to Password. All. Instead, an encrypted version of each password 
is provided. When a user links to his passthrough page in Password- All at 

20 the Password-All Portal server, when he/she invokes a hyperlink, the 

encrypted password is returned to the user's system, which then, by virtue of 
the kept encryption key or master password, invokes the true and necessary 
password for connection to the selected destination. It is thus not necessary 
that cleartext passwords be stored at the Password- All Portal server, where 

25 they may be vulnerable to attack from outside sources, or to perceived 
misuse in other ways as well. 

In a related safety measure, in a preferred embodiment of the 
invention, a user's complete profile is never stored on a single server, but is 
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distributed over two or more, preferably more, servers, so any problem with 
any one server will minimize the overall effect for any particular user. 

Password-All, as described above, allows a user to access a complete 
list of the user's usual cyberspace destinations, complete with necessary log- 

5 on data, stored in an encrypted fashion, so a user may simply select a 

destination (a hyperlink) in the Password-All list, and the user's browser then 
invokes the URL for the selected destination. In an added feature, 
Password- All may display banner ads and other types of advertisement 
during the navigation time between a hyperlink being invoked and the time 

10 the destination WEB page is displayed. 

In yet another embodiment of the invention, a user/subscriber need 
not access the Password-All page to enjoy the advantages of the unique 
features provided. In this variation, a Plug-In is provided for the subscriber's 
WEB browser. If the subscriber navigates by use of the local browser to a 

15 WEB page requiring a secure log-in, such as his/her on-line banking 

destination, when the subscriber is presented with an input window for ID 
and Password, the plug in may be activated by a predetermined user input, 
such as a hot key or right click of the mouse device. The plug-in then 
accesses, transparently, the Password-All page (which may be cached at the 

20 client), and automatically accesses and provides the needed data for log-on. 

In yet another aspect of the invention a search option 37 allows a 
user to search list 34 for specific URLs based on typed input such as 
keywords or the like. In some cases, the number of URLs stored in list 34 
can be extensive making a search function such as function 37 an attractive 

25 option. A criteria dialog box 5 1 illustrated as logically separated from and 
below list 34 is provided and adapted to accept input for search option 37 as 
is known in the art. In one embodiment search option 37 may bring up a 
second window wherein a dialog box such as box 5 1 could be located. 
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In another aspect of the invention the search function may also be 
configured in a window invoked from window 33, and caused to search all 
or selected ones of listed destinations, and to return results in a manner that 
may be, at least to some extent, configured by a user. For example, a dialog 

5 box may be presented wherein a user may enter a search criteria, and select 
among all of the listed destinations. The search will then be access each of 
the selected destinations in turn, and the result may be presented to the user 
as each instance of the criteria is found, or results may be listed in a manner 
to be accessed after the search. 

10 Preferably the search function is a part of the Password-All Portal 

software, available for all users, and may be accessed by hyperlinks in user's 
personal pages. In some embodiments users may create highly individualized 
search functions that may be stored in a manner to be usable only by the user 
who creates such a function. 

15 In many aspects of the present invention, knowledge of specific WEB 

pages, and certain types of WEB pages, is highly desirable. In many 
embodiments characteristics of destination WEB pages are researched by 
persons (facilitators) maintaining and enhancing Password- All Portal 
software 35, and many characteristics may be provided in configuration 

20 modules for users to accomplish specific tasks. In most cases these 
characteristics are invoked and incorporated transparent to the user. 

In yet another aspect of the present invention, the Password-All 
suite is structured to provide periodic reports to a user, in a manner to be 
structured and timed by the user, through the user's profile. For example, 

25 reports of changes in account balances in bank accounts, stock purchases, 
stock values, total airline travel purchases, frequent-flier miles, and the like 
may be summarized and provided to the users in many different ways. 
Because the Password-All Portal server with the Password- All software site 
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handles a broad variety of transactional traffic for a user, there is an 
opportunity to summarize and collect and process statistics in many useful 
ways. In preferred embodiments of the invention such reports may be 
furnished and implemented in a number of different ways, including being 
5 displayed on the user's secure personal WEB page on the Password- All 
Portal. 

In addition to the ability of performing tasks as described above, task 
results including reports, and hard documents such as airline tickets may be 
sent over the Internet or other data packet-networks to user-defined 

10 destinations such as fax machines, connected computer nodes, e-mail 

servers, and other Internet-connected appliances. All tasks may be set-up 
and caused to run according to user-defined schedules while the user is 
doing something else or is otherwise not engaged with the scheduled task. 
In another embodiment of the present invention, recognizing the 

15 increasing use of the Internet for fiscal transactions, such as purchasing 

goods and services, a facility is provided in a user's profile to automatically 
track transactions made at various destinations, and to authorize payment 
either on a transaction-by-transaction basis, or after a session, using access 
to the user's bank accounts, all of which may be pre-programmed and 

20 authorized by the user. 

Other functions or options illustrated as part of application 35 
include a last URL option 41, an update function 43 , and an add function 45. 
Function 41 allows a user to immediately navigate to a last visited URL. 
Update function 43 provides a means of updating URLs for content and new 

25 address. An add function enables a user to add additional URLs to list 34. 
Similarly, function 45 may also provide a means to delete entries. Other 
ways to add accounts are described above. It should be noted that the 
services provided by the unique Password- All Portal in embodiments of the 
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present invention, and by the Password- All software suite are not limited to 
destinations requiring passwords and user names. The Password- All Portal 
and software in many embodiments may also be used to manage all of a 
user's bookmarks, including editing of bookmarks and the like. In this 

5 aspect, bookmarks will typically be presented in indexed, grouped, and 
hierarchical ways. 

There are editing features provided with Password- All for adding, 
acquiring, deleting, and otherwise managing bookmarks. As a convenience, 
in many embodiments of the invention, bookmarks may be downloaded from 

10 a user's Password-All site, and loaded onto the same user's local browser. In 
this manner, additions and improvements in the bookmark set for a user may 
be used without the necessity of going to Password-All Further, bookmarks 
may be uploaded from a user's local PC to his/her home page on the 
Password-All site by use of one or more Password-All plug-ins. 

15 It will be apparent to the skilled artisan, given the teaching herein, 

that the functionality provided in various embodiments of the invention is 
especially applicable to Internet-capable appliances that may be limited in 
input capability. For example, a set-top box in a WEB TV application may 
well be without a keyboard for entering IDs and Passwords and the like. In 

20 practice of the present invention keyboard entry is minimized or eliminated. 
The same comments apply to many other sorts of Internet appliances. 

In preferred embodiments of the invention, once a subscriber-user is 
in Password- All, only an ability to point-and-click is needed for all 
navigation. To get into the Password-All site, using a limited apparatus, 

25 such as an appliance without a keyboard or keypad, a Smartcard or 

embedded password may be used, or some other type of authentication. 

It will be apparent to one with skill in the art that an interactive 
application such as application 33 may be provided in a form other than a 
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WEB page without departing from the spirit and scope of the present 
invention. For example, an application such as application 33 may be 
provided as a downloadable module or program that may be set-up and 
configured off-line and made operational when on-line. 

5 Fig. 3 is a flow diagram illustrating user interaction with the Internet 

Password-All Portal of fig. 1 . The following process steps illustrated, 
according to an embodiment of the present invention, are intended to 
illustrate exemplary user-steps and automated software processes that may 
be initiated and invoked during interaction with an Internet portal of the 

10 present invention such as portal 3 1 of Fig. 1. In step 53 a user connects to 
the Internet or another previously described switched-packet network via a 
compatible appliance such as Internet appliance 17 of Fig. 1. 

At step 55, a user enters a user-name and password, which, In one 
embodiment may simply be his ISP user name and password. In another 

15 embodiment a second password or code would be required to access an 
Internet portal such as portal server 3 1 of Fig. 1 after logging onto the 
Internet through the ISP. In some cases, having a special arrangement with 
the ISP, there may be one password for both Internet access through the ISP 
and for Password-All At step 57 a personal WEB page such as page 32 of 

20 Fig. 2 is displayed via Internet portal server 3 1 . At minimum, the 

personalized WEB page will contain all user configured URLs, and may also 
be enhanced by a search function, among other possibilities. 

In step 58 a user will, minimally, select a URL from his or her 
bookmarked destinations, and as is known by hyperlink technology, the 

25 transparent URL will be invoked, and the user will navigate to that 

destination for the purpose of normal user interaction. In this action, the 
Password- All Portal software transparently logs the user on to the 
destination page, if such log-on is needed. 
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At step 60 the user invokes a search engine by clicking on an option 
such as described option 37 of Fig. 2. At step 62, the user inputs search 
parameters into a provided text field such as text field 51 of Fig. 2. After 
inputting such parameters, the user starts the search by a button such as 

5 button 52. The search engine extracts information in step 64. Such 
information may be, in one option, of the form of URLs fitting the 
description provided by search parameters. A searched list of URLs may be 
presented in a separate generated page in step 66 after which a user may 
select which URL to navigate to. In an optional search function, the user 

10 may provide search criteria, and search any or all of the possible destinations 
for the criteria. 

In another embodiment wherein WEB pages are cached in their 
presentable form, information extracted in step 64 may include any 
information contained in any of the stored pages such as text, pictures, 
15 interactive content, or the like. In this case, one displayed result page may 
provide generated links to search results that include the URL associated 
with the results. Perhaps by clicking on a text or graphic result, the 
associated WEB page will be displayed for the user with the result 
highlighted and in view with regards to the display window. 

20 

Enhanced Agent for WEB Summaries 

In another aspect of the present invention, a software agent, termed a 
gatherer by the inventors, is adapted to gather and return summary 
25 information about URLs according to user request or enterprise discretion. 
This is accomplished in embodiments of the present invention by a unique 
scripting and language parsing method provided by the inventor wherein 
human knowledge workers associated with the service provide written 
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scripts to such a gatherer according to subscriber or enterprise directives. 
Such a software gatherer, and capabilities thereof, is described in enabling 
detail below. 

Referring now to Fig. 1, there is illustrated an exemplary architecture 

5 representing a portal service-network which, in this case is hosted by ISP 15. 
Portal software 35 in this embodiment executes on portal server 3 1 set-up at 
the ISP location. Mass repository 29 is used for storing subscriber 
information such as passwords, login names, and the like. Internet servers 
23, 25, and 27 represent servers that are adapted to serve WEB pages of 

10 enterprises patronized by a subscriber to the portal service such as one 
operating Internet appliance 17. 

The main purpose of portal software 35 as described above with 
reference to Fig. 2, is to provide an interactive application that lists all of the 
subscriber's WEB sites in the form of hyperlinks. When a user invokes a 

15 hyperlink from his personal list, software 35 uses the subscriber's personal 
information to provide an automatic and transparent login function for the 
subscriber while jumping the subscriber to the subject destination. 

Referring again to Fig. 2, an interactive list 34 containing user- 
entered hyperlinks and a set of interactive tools is displayed to a subscriber 

20 by portal software 35 of Fig. 1. One of the tools available to a subscriber 
interacting with list 34 is agent (software) 39. Agent 39 may be 
programmed to perform certain tasks such as obtaining account information, 
executing simple transactions, returning user-requested notification 
information about upcoming events, and so on. Search function 37 and 

25 update function 43 may be integrated with agent 39 as required to aid in 
functionality. 

It is described in the above disclosure that agent 39 may, in some 
embodiments, search for and return certain summary information contained 
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on user-subscribed WEB pages, such as account summaries, order tracking 
information and certain other information according to user-defined 
parameters. This feature may be programmed by a user to work on a 
periodic time schedule, or on demand. 

5 In the following disclosure, enhancements are provided to agent 39. 

Such enhancements, described in detail below, may be integrated into agent 
39 of portal software 35 (Fig.'s 1 and 2); and may be provided as a separate 
agent or gatherer to run with portal software 35; or may, in some 
embodiments, be provided as a standalone service that is separate from 

10 portal software 3 5 . 

Fig. 4 is a block diagram illustrating a summarization software agent 
67 and various capabilities and layers thereof according to an embodiment of 
the present invention. Summarization agent 67, hereinafter termed gatherer 
67, is a programmable and interactive software application adapted to run on 

15 a network server. Gatherer 67 may, In one embodiment be integrated with 
portal software 35 of Fig. 1 and be provided in the form of a software 
module separate from agent 39 (Fig. 2). In another embodiment gatherer 67 
may be a part of agent 39 as an enhancement to the function of that agent as 
previously described. In still another embodiment, gatherer 67 may be 

20 provided as a parent or client-side application controlled by a separate 
service from the portal service described above. 

In this exemplary embodiment gatherer 67 is a multi-featured 
software application having a variety of sub-modules and interface modules 
incorporated therein to provide enhanced function. Gatherer 67 has a 

25 client/service interface layer 69 adapted to enable directive input from both a 
client (user) and a knowledge worker or workers associated with the service. 
A browser interface 77 is provided in layer 69, and adapted to provide 
access to application 67 from a browser running on a client's PC or other 
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Internet or network appliance. Interface 77 facilitates bi-directional 
communication with a user's browser application (not shown) for the 
purpose of allowing the user to input summary requests into gatherer 67 and 
receive summary results. Interface 77 supports all existing network 

5 communication protocols such as may be known in the art, and may be 
adapted to support future protocols. 

Layer 69 also comprises a unique input scripting module 79 that is 
adapted to allow a human knowledge worker to create and supply directive 
scripts containing the site logic needed by gatherer 67 to find and retrieve 

10 data from a WEB site. In this case, gatherer 67 executes and runs on a 

network server such as server 3 1 of Fig. L However, this is not required in 
order to practice the present invention. 

It is assumed in this example that gatherer 67 is part of the portal 
software suite 35 running on server 3 1 of Fig. 1 . Gatherer 67 may be 

15 provided as several dedicated agents, or as one multi-functional agent 

without departing from the spirit and scope of the present invention. For 
example, one gatherer 67 may be scripted and programmed to execute a 
single user request with additional gatherers 67 called upon to perform 
additional user-requests. Alternatively, one gatherer 67 may be dedicated 

20 and assigned to each individual user and adapted to handle all requests from 
that user. 

Interface layer 69 facilitates exchange of information from both a 
client and a knowledge worker. A client operating a WEB browser with an 
appropriate plug-in is enabled to communicate and interact with gatherer 67. 
25 For example, a user may enter a request to return a summary of pricing for 
all apartments renting for under $1000.00 per month located in a given area 
(defined by the user) from apartments.com (one of user's registered WEB 
sites). The just mentioned request would be categorized as either a periodic 
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request, or a one time (on demand) request. The communicated request 
initiates a service action wherein a knowledge worker associated with the 
service uses module 79 to set-up gatherer 67 to perform it's function. 
Module 79 is typically executed from a network-connected PC operated by 

5 the knowledge worker. 

According to an embodiment of the present invention, a unique 
scripting method facilitated by module 79 is provided to enable gatherer 67 
to obtain the goal information requested by a user. For example, the above 
mentioned example of WEB-site apartments.com has a specific HTML 

10 (hyper-text-markup-language) logic that it uses to create its site and post its 
information. Such site logic is relatively standard fare for a majority of 
different sites hosted by different entities. Using this knowledge, a 
knowledge worker creates a site-specific script or template for gatherer 67 
to follow. Such a template contains descriptions and locations of the 

15 appropriate fields used, for example, at apartments.com. Apartment 

description, location, deposit information, rental information, agent contact 
information, and other related fields are matched in terms of location and 
label description on the template created with module 79. Completed 
templates are stored in a database contained in a storage facility such as, 

20 perhaps, repository 29 of Fig. 1 . Such templates may be reused and may be 
updated (edited) with new data. 

In one embodiment one script may contain site logics for a plurality 
of WEB pages, and instructions for specific navigational instruction and 
password or login information may be contained therein and executed 

25 serially, such as one site at a time. It is important to note that the knowledge 
worker or workers may perform much of their scripting via automatic 
controls such as by object linking and embedding (OLE) and a minor portion 
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of scripting may be performed manually in an appropriate computer 
language, many of which are known in the art). 

Gatherer 67 also has a process layer 71 adapted for internal 
information gathering and parameter configuration. An optional portal 

5 server interface 81 is provided and adapted to allow gather 67 to provide 
updated information to a user's list of hyperlinks and also to obtain data 
from portal server 3 1 if required. For example, required hyperlinks may be 
mirrored from a user's home page to a scripting template for navigational 
purposes. In an embodiment wherein gatherer 67 is part of a standalone 

10 service, a convention for providing user login information may be supplied at 
the client's end when a request is made. For example, an encrypted 
password may be supplied by a client plug-in and gatherer 67 may 
temporarily borrow the user's encryption key when auto login is performed. 
An appliance configuration module 83 is provided and adapted to 

15 allow a user to define and configure an Internet appliance to communicate 
with the service and receive summary information. Such appliances may 
include but are not limited to palm top PC's, lap top PC's, cellular 
telephones, WEB TV's, and so on. Typically, a user will be presented a 
configuration WEB page from a network server that displays in his browser 

20 window on his desktop PC. The page contains an interface for 

communicating device parameters and communication protocol types to 
module 83. In this way, a user may configure a preferred device for receipt 
of summary information. Device parameters and communication protocols 
inherent to such a device are incorporated into the scripting of the site 

25 template and are used as instructions for WEB summary delivery. 

A navigation layer 73 is provided and adapted to perform the 
function of external site navigation and data gathering for gatherer 67. To 
this end, a communication interface/browser control module 85 is provided 
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and adapted to function as a WEB browser to access WEB sites containing 
WEB data. Control 85 receives it's instruction from the scripted template 
created by the knowledge worker. 

A parsing engine 87 is provided and adapted to parse individual 

5 WEB sites according to a template created via scripting module 79. Parsing 
engine 87 may be a Pearl engine, an IE HTML engine, or any other or 
combination of known parsing engines. The template (not shown) tells 
control 85 and parsing engine 87 where to go and what fields at the 
destination site to look for to access desired data. Once the data fields are 

10 located, parsing engine 87 gathers current data in the appropriate field, and 
returns that data to the service for further processing such as data 
conversion, compression and storage, and the like. 

Because WEB sites use tools that use consistent logic in setting up 
their sites, this logic may be used by the summarization service to instruct 

15 control 83 and parsing engine 87. The inventor provides herein an 
exemplary script logic for navigating to and garnishing data from 
amazon™.com. The hyperlinks and/or actual URLs required for navigation 
are not shown, but may be assumed to be included in the template script. In 
this example, a company name Yodlee (known to the inventors) is used in 

20 the script for naming object holders and object containers, which are in this 
case Active X™ conventions. In another embodiment Java™ script or 
another object linking control may be used. The scripted template logic 
example is as follows: 

# Site amazon.orders.x - shows status of orders from Amazon 

25 

login( 7 ); 

get( 7exec/obidos/order-list/" ); 
30 my @tables = get_tables_containing_text( "Orders:" ); 
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my $order_list = new Yodlee::ObjectHolder( 'orders' ); 
$order_list->source( 'amazon' ); 
$order_list->link_info( get_link_info() ); 

5 my @href_list; 

my @container_list; 

foreach my Stable ( @tables ) { 

my @rows = get_table_rows(); 

10 

foreach my $i ( 0 .. $#rows ) { 
select_row( $i ); 

my $text = get_text( $rows[ $i ] ); 
next if $text =~ /Orders: | Status/; 

15 

my @items = getj*ow_items(); 
next unless @items >= 4; 

my( $order_num ? $date ? $status ); 
20 select_cell( 1 ); 

$orderjium = get_cell_text(); 

my $href = get_url_of_first__href( get_cell() ); 

25 select_cell( 2 ); 

$date = get__cell_text(); 

select_cell( 3 ); 

Sstatus = get__cell_text(); 

30 next unless defined $order_num and defined $date and defined 

Sstatus; 

my $order = new Yodlee::Container( 'orders' ); 
$order->order_number( $order_num ); 
35 $order->date( $date ); 

$order->status( $status ); 

$order_list->push_object( $order ); 

40 if( defined $href) { 

push( @href_list, $href ); 
push( @container_list 3 Sorder ); 
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foreach my $i ( 0 .. $#href_list ) { 
get( $href_list[ $i ] ); 

@tables = get__tables_containing_text( "Items Ordered:" ); 

foreach my Stable ( @tables ) { 

my @rows = get_table_rows(); 

foreach my $j ( 0 .. $#rows ) { 
select_row( $j ); 

my $href = get_url__of_first_href( get_row() ); 

next unless defined $href; 

my @child_list = get_children( get_row(), 'a* ); 
next unless defined $child_list[ 0 ]; 

my $text = get Jext( $childjist[ 0 ] ); 

Scontainer Jist[ $i ]->description( $text ); 

} 

} 

} 

result( $order Jist ); 

The above example is a script that instructs control 85 and parser 87 
to navigate to and obtain data from Amazon™, com, specifically that data 
that reflects the user's current order status. Scripts may also be written to 
obtain virtually any type of text information available from any site. For 
example, a user may wish to obtain the New York Times headlines, the top 
ten performing stocks, a comparative list of flights from San Francisco to 
New York, etc. In one embodiment metadata may be associated with and 
used in-place of the actual scripted language for the purpose of reducing 
complication in the case of many scripts on one template. 
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A data processing layer 75 is provided and adapted to store, process, 
and present returned data to users according to enterprise rules and client 
direction. A database interface module 89 is provided and adapted to 
provide access for gatherer 67 to a mass repository such as repository 29 of 
Fig. 1, for the purpose of storing and retrieving summary data, templates, 
presentation directives, and so on. Gatherer agent 67 may also access data 
through interface 89 such as profile information, user account and URL 
information, stored site logics and so on. Data scanned from the WEB is 
stored in a canonical format in a database such as repository 29, or in 
another connected storage facility. All stored data is, of course, associated 
with an individual who requested it, or for whom the data is made available 
according to enterprise discretion. 

A summarization page module 91 is provided and adapted to 
organize and serve a WEB summary page to a user. Module 91, in some 
embodiments, may immediately push a WEB summary to a user, or module 
91 may store such summarized pages for a user to access via a pull method, 
in which case a notification may be sent to the user alerting him of the 
summary page availability. Summarization module 91 includes an HTML 
renderer that is able to format data into HTML format for WEB page 
display. In this way, e-mail messages and the like may be presented as 
HTML text on a user's summarization page. Moreover, any summary data 
from any site may include an embedded hyperlink to that site. In this way, a 
user looking at an e-mail text in HTML may click on it and launch the 
appropriate e-mail program. Other sites will, by default, be linked through 
the summary page. 

Many users will access their summary data through a WEB page as 
described above, however, this is not required in order to practice the 
present invention. In some embodiments, users will want their summary 
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information formatted and delivered to one of a variety of Internet-capable 
appliances such as a palm top or, perhaps a cell phone. To this end, the 
renderer is capable of formatting and presenting the summary data into a 
number of formats specific to alternative devices. Examples of different 

5 known formats include, but are not limited to XML, plain text, VoxML, 
HDML, audio, video, and so on. 

In a preferred embodiment of the present invention gather 67 is 
flexible in such a way as it may act according to enterprise rules, client 
directives, or a combination of the two. For example, if a user makes a 

10 request for summary data about a user/subscribed WEB page to be 

periodically executed and presented in the form of a HTML document, then 
gather 67 would automatically access and analyze the required internal 
information and user provided information to formulate a directive. Using 
scripting module 79, a knowledge worker provides a template (if one is not 

15 already created for that site) that contains the "where to go" and "what to 
get" information according to site logic, user input, and known information. 

Alternatively, if a user requests a summary about data on one of his 
sites such as, perhaps, current interest rates and re-finance costs at his 
mortgage site, the service may at it's own discretion provide an additional 

20 unsolicited summary from an alternate mortgage site for comparison. This 
type of summarization would be designed to enhance a user's position based 
on his profile information. In this case, updated data about latest interest 
rates, stock performances, car prices, airline ticket discounts, and so on 
would be stored by the service for comparative purposes. If a user request 

25 for a summary can be equaled or bettered in terms of any advantage to the 
user, such summary data may be included. 

In many cases, created templates may be re-used unless a WEB site 
changes it's site logic parameters, in which case, the new logic must be 
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accessed and any existing templates must be updated, or a new template may 
be created for the site. The templates contain site-specific script obtained 
from the site and stored by the knowledge workers. In one embodiment 
companies hosting WEB pages automatically provide their site logics and 
5 any logic updates to the service by virtue of an agreement between the 
service and the WEB hosts. 

In an alternative embodiment gatherer 67 may be implemented as a 
client application installed on a user's PC. In this embodiment, a user would 
not be required to supply log-in or password codes. Summarization scripts 

10 may be sent to the client software and templates may be automatically 

created with the appropriate scripts using log-in and password information 
encrypted and stored locally on the user's machine. 

In addition to providing WEB summary information, gatherer 67 may 
also be used to provide such as automatic registration to new sites, and for 

15 updating old registration information to existing sites. For example, if a user 
whishes to subscribe, or register at a new site, only the identification of the 
site is required from the user as long as his pertinent information has not 
changed. If a new password or the like is required, gatherer 67 through 
control module 73 may present login or password codes from a list of 

20 alternative codes provided by a user. In another embodiment a database (not 
shown) containing a wealth of password options may be accessed by 
gatherer 67 for the purpose of trying different passwords until one is 
accepted by the site. Once a password or log-in code is accepted, it may be 
sent to a user and stored in his password list and at the network level. 

25 It will be apparent to one with skill in the art that a software 

application such as gatherer 67 may be implemented in many separate 
locations connected in a data network. For example, a plurality of gatherer 
applications may be distributed over many separate servers linked to one or 
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more mass repositories. Client applications include but are not limited to a 
WEB -browser plug-in for communicating to the service. Plug-in extensions 
may also be afforded to proxy servers so that auto-login and data access may 
still be performed transparent to a user. 
5 In another embodiment plug-ins enabling communication with 

gatherer 67 may be provided and configured to run on other network devices 
for the purpose of enabling such a device to initiate a request and get a 
response without the need for a desktop computer. 

In most embodiments a user operating a desktop PC will order a one 
10 time or periodic summary related to some or all of his subscribed WEB sites. 
A logical flow of an exemplary request/response interaction is provided 
below. 

Fig. 5 is a logical flow chart illustrating an exemplary summarization 
process performed by the software agent of Fig. 4 operating in a user- 

15 defined mode. In step 93, a user has initiated a new request for a summary 
(summary order). It is assumed for the purpose of discussion, that the 
request of step 93 involves a site wherein no template has been created. In 
step 95, the request is received and analyzed. A knowledge worker will 
likely perform this step. The new request may be posted to the user's portal 

20 home page, sent directly to gatherer 67, or even communicated through e- 
mail or other media to the service. 

In step 97 a knowledge worker accesses particular site logic 
associated with the request URLs. For example, if the request involves a 
plurality of URLs, then all site logics for those URLs are accessed. Logic 

25 may be available in a repository such as repository 29 of Fig. 1 if they were 
obtained at the time of user registration to a particular URL, or sent in by 
WEB-site hosts shortly after registration. If it is a completely new URL, 
then the logic must be obtained from the site. In most cases however, the 
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logic will be known by virtue of a plurality of users accessing common 
URLs. Therefore cross-linking in a database of logic/user associations may 
be performed to access a logic for a site that is new to one particular user, 
but not new to another. 

5 In step 99, the knowledge worker creates a template by virtue of 

scripting module 79 (Fig. 4) containing all site logic, URLs, log-in and 
password information, and the user request information. As described 
previously, templates may be re-used for a same request. In most cases, 
scripting may be mostly automated with minimum manual input performed 

10 by the knowledge worker. In many cases, an existing template will match a 
new request exactly, and may be re-used. In that case steps 97, 99, and 101 
would not be required. 

In step 101 the template is stored and associated with the requesting 
user. The stored template may now be retrieved at a scheduled time for 

15 performing the summary gathering. At step 103, a browser control such as 
module 85 of Fig. 4 is activated to access the stored template and navigate 
to specified URLs for the purpose of gathering summary data. If a timing 
function is attributed to the template stored in step 101, then the template 
may self execute and call up the browser function. In another embodiment 

20 the knowledge worker may notify the browser control to get the template for 
it's next task. In some embodiments, a plurality of controls may be used 
with one template as previously described. 

In step 105, automatic log-in is performed, if required, to gain access 
to each specified URL. In step 107, a specified WEB page is navigated to 

25 and parsed for requested data according to the logic on the template. If 
there are a plurality of WEB -pages to parse, then this step is repeated for 
the number of pages. A variety of parsing engines may be used for this 



-38- 

process such as an IE™ parser, or a Pearl™ parser. Only the requested data 
is kept in step 107, 

A request may be an on-demand request requiring immediate return, 
or a scheduled request wherein data may be posted. At step 109, such logic 

5 is confirmed. If the data is to be presented according to a periodic schedule, 
then summary data parsed in step 107 is stored for latter use in step 111. In 
step 1 13, the summary data is rendered as HTML if not already formatted, 
and displayed in the form of a summary WEB page in step 115. The 
summary page may be posted for access by a user at a time convenient to the 

10 user (pull), or may be pushed as a WEB page to the user and be made to 
automatically display on the user's PC. Notification of summary page 
availability may also be sent to a user to alert him of completion of order. 

If the summary data is from a one-time on-demand request and 
required immediately by a user, then a network appliance and data delivery 

15 method (configured by the user) is confirmed, and the data is rendered in the 
appropriate format for delivery and display in step 1 17. In step 119, the 
summary data is delivered according to protocol to a user's designated 
appliance. In step 121a user receives requested information in the 
appropriate format. 

20 It will be apparent to one with skill in the art that there may be more 

or fewer logical steps as well as added sub-steps than are illustrated in this 
example. For example, step 105 may in other embodiments include sub- 
steps such as getting an encryption key from a user. In still another 
embodiment, part of a request may be rendered as HTML as in step 1 13 

25 while certain other portions of the same request data might be rendered in 
another format and delivered via alternative methods. There are many 
possibilities. 
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The method and apparatus of the present invention may be used to 
present summaries to users without user input. Process logic such as this is 
detailed below. 

Fig. 6 is a logical flow chart illustrating an exemplary summarization 
5 process performed by the software agent of Fig. 4 in a User-independent 
smart mode with minimum or no user input. In step 1 17 an enterprise- 
initiated summary process begins. In this case, the enterprise may be 
assisting a user in finding a better deal or, perhaps presenting the individual 
with summaries from and links to alternative pages not yet subscribed to by a 
10 user. 

In step 1 19, a database containing user information and parameters is 
accessed and reviewed. Certain information specific to a user may be 
required to initiate an enterprise-sponsored summary report. At step 121, 
the knowledge worker accesses the site logic specific to the specified target 
15 site or sites for summarization. In step 123, the knowledge worker modifies 
an existing user template, or creates a new one if necessary. At step 125 the 
template is stored in a repository such as repository 29 and associated with 
the user. 

As described in Fig. 5, the template either self-executes according to 
20 a timed function and invokes a browser control such as control 85 (Fig. 4), 
or is accessed by control 85 as a result of task notification. In step 127, the 
browser control begins navigation. Auto logins are performed, if required, 
in step 129 to gain access to selected sites. If the WEB pages are new to a 
user, and the user has no registration with the WEB site, then through 
25 agreement, or other convention, the service may be provided access to such 
sites. Such an agreement may be made, for example, if the host of the WEB 
site realizes a possibility of gaining a new customer if the customer likes the 
summary information presented. In many other situations, no password or 



-40- 

login information is required to obtain general information that is not 

personal to a client. 

In step 131, all sites are parsed for summary data and stored in 

canonical fashion in step 133. At step 135, the data is compiled and 
5 rendered as HTML for presentation on a summary page. In step 137, a 

WEB summary containing all of the data is made available to a user and the 

user is notified of its existence. 

Providing certain information not requested by a user may aid in 

enhancing a user's organization of is current business on the WEB. 
10 Moreover, unsolicited WEB summaries may provide better opportunities 

than the current options in the user's profile. Of course, assisting a user in 

this manner will require that the enterprise (service) have access to the user's 

profile and existing account and service information with various WEB sites 

on the user's list. A user may forbid use of a user's personal information, in 
15 which case, no enterprise-initiated summaries would be performed unless 

they are conducted strictly in an offer mode instead of a comparative mode. 

Enhanced Data Parsing and Logic Integration 

20 In another aspect of the present invention, a software application is 

provided and adapted to recognize and parse data from semi-structured, 
WEB-based data sources on behalf of a user. 

Referring to Figs. 1-3 of application S/N 09/208,740, a portal system 
for interacting with WEB-based data is enabled by portal software 35 

25 running on portal server 3 1 located, in this case, at ISP 15 of Fig. 1. 

Software 35 allows users who are connected to server 3 1 via Internet 
network connection, to access pre-configured URLs without requiring 
manual log-in procedures to be performed. 
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Portal Interface 37 is an Interactive WEB page, which may be 
personalized to a specific user. In the example of Fig. 2, page 37 displays 
user-visited links and encrypted passwords to those links. Page 37 also 
provides software tools a user may invoke to search for data either from his 
5 or her stored hyperlinks, or from specified fields within the pages defined by 
the hyperlinks. The example process of Fig. 3 illustrates the above-described 
function. 

Figs. 4-6 of S/N 09/323,598 illustrate a method and apparatus for 
performing meta-summarization of WEB-based data on behalf of a user 

10 according to user request. Navigation to search the data is performed by 
proxy using what is termed a gatherer agent (software). Site-logic scripts 
are prepared by knowledge workers for navigation to the separate user sites. 
The scripts are typically Java-based executable routines combined with 
specific data descriptions and, if required, field location information provided 

15 by the user at the time of request. A user may request summary data from a 
plurality of sites and get the data returned on demand, or have it held by the 
system for later access. 

As previously described in the background section, field locations for 
data must be provided in order for the parsing engine to identify and return 

20 specified data in a structured arrangement. An input template provides 
instruction to the parser concerning what data to obtain for return. The 
template is created in part by user input through the portal interface and in 
part by knowledge worker providing data-navigation instruction, which may 
include field locations for structured data. 

25 The system partly relies on the fact that data requested by a user will 

appear at a same location (field) within a WEB page every time the system 
searches for it. The field location then becomes a critical part of finding the 
data. The inventor provides an enhancement to the WEB-summary system 
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that allows the system to search for and parse data without the constraint of 
adhering to rigid data structures. Such a method and apparatus is described 
below. 

Fig. 7 is a block diagram illustrating a user-interactive set-up 

5 application 139 according to an embodiment of the present invention. 

Application 139 is, In a preferred embodiment a graphical tool provided to 
users and accessible through their respective portal pages. A user invokes 
application 139 when he or she desires to pre-configure profiled data sources 
for meta-summarization. In a preferred embodiment activation of 

10 application 139 causes an interactive browser window to open within a 
user's portal page. By working within the window, a user may pre- 
configure sites for data acquisition. 

Application 139 comprises an initialization layer 141 adapted for user 
interface, and a document type definition (DTD) generation layer 143 

15 adapted to generate DTDs, which describe selected data sources. 

Initialization layer 141 has a browser control module 145 provided therein 
and adapted as a browser extension for navigation to selected URLs. 
Application 139 may be integrated with a user's browser application such 
that the presented window of application 139 is a browser window as 

20 described above. A user-data interface 147 is provided within layer 141 and 
adapted as a data-input field for entering URLs for navigation purposes. By 
entering a URL into interface 147 ? browser control module 145 causes 
navigation to and presentation of the WEB page defined by the entered 
URL. 

25 Presentation of the selected WEB page is conducted utilizing the 

well-known multi-window technology such that the WEB page may be 
displayed within the window of application 139 while leaving other controls 
attributed to application 139 visible and accessible to a user. One such 
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control is a block selection module 149, which is adapted as a user- 
controlled highlighter for selecting specific parts of a WEB page containing 
data that is desired by the user to be accessed. Module 149 may function by 
combination of keyboard manipulation and mouse click similar to well- 

5 known text selection tools available in word applications. 

A selection- submission module 15 1 is provided within layer 141 and 
implemented to allow a user to submit selected portions of a WEB page to 
the portal system for DTD generation. Highlighting or blocking a section of 
a WEB page defines the boundaries for data search. A user must also 

10 specify the type of data to be extracted from the highlighted area of the 
WEB page. 

In practice a user may call-up many WEB pages, highlight (define) 
sections of each page, and provide data descriptions for data extraction with 
regard to each page all in one session with application 139. The method 

15 described above comprises a meta-data request wherein the returned results 
are aggregated and displayed to, or otherwise made available to users 
according to enterprise rules. The output of layer 141 is a highlighted 
portion of a "structure tree" describing the HTML data structure used to 
display the data on the target WEB site along with associated data-type 

20 descriptions input by a user. 

A data structure tree defines how data is displayed on a WEB page in 
HTML format. An application program interface (API), which is part of the 
normal browser function understands the HTML data structure used in the 
construction of a WEB page, which is available at the source. Therefore, a 

25 specific structure tree is captured by browser module 145 every time an 
associated WEB page is displayed in application window 139. User- 
highlighted portions of a WEB page define "portions" of the overall data 
structure tree of that page. Therefore, the output of layer 141 comprises an 
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entire data structure tree for a WEB page, a highlighted portion of that data 
structure, and a description of the type of human-readable data to be 
extracted from that portion of the tree. 

Layer 143 is responsible for producing DTDs adapted to facilitate 

5 data search and extraction. A DTD generator is provided within layer 143 
and adapted to generate a DTD of a data source using information supplied 
by layer 141 . A DTD is a template written in a language such as XML that 
is understood by a browser/data-parsing application. In a preferred 
embodiment a DTD is created in Extensible Markup Language (XML), 

10 however, any standard script language may be employed such as Standard 
Generalized Markup Language (SGML). A DTD is generated for each 
portion of a WEB page a user highlights. 

A database interface module 155 is provided within layer 143 and 
adapted to allow interface to a connected database for the purpose of 

15 obtaining site-logic scripts for navigation, which include log-in blocks for 

performing automated log-in function for sites requiring passwords. In some 
cases new site-logic scripts are required if data is to be extracted from a new 
page. Interface 155 may also be used to obtain any other useful information. 
A DTD/site-logic integration module 157 is provided within layer 

20 143 and adapted to create a routine combining site logic and DTD templates 
in such a way that navigation and data extraction is performed seamlessly 
and automatically. For example, a site logic script with a log-in block is 
used to navigate to and access a particular URL, then a DTD template 
portion reveals where on that URL page to look for data and what type of 

25 data to extract from the URL page. Information gathering for a next URL 
would follow a next site-logic and DTD instruction contained in the routine 
and marked for that URL and so on. An automated navigation and data 
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extraction routine may facilitate a plurality of URLs included in one data 
search execution. 

It is conceivable that one routine containing the required instruction 
blocks could facilitate automated navigation and information retrieval from a 

5 great many URLs during one automated routine on behalf of a user. A 
single WEB site or a combination of, or all of a user's WEB sites may be 
processed for data during a single automated process. All that is required of 
a user is to first set-up a URL or URLs for data searching by navigating to 
them, highlighting portions contained therein, and providing a description of 

10 the type of data to be extracted. Once set-up, summary data from the 

affected URL pages may be periodically gathered on behalf of the user and 
presented in a variety of ways, some of which are described in disclosure 
pertaining to S/N 09/208,740 and S/N 09/323,598. 

It will be apparent to one with skill in the art that application 139 as 

15 exemplified above is provided to execute as a network-supported application 
on a client. In this example, layer 141 is provided to execute as a client-side 
application while layer 143 is provided and executed at server side. 
Communication and cooperation between layers 141 and 143 is achieved 
through appropriate network-interface technologies known in the art. Proxy 

20 navigating and data gathering is executed at the server side on behalf of a 
user. In one embodiment all of the function of application 139 may be 
provided at the client's side. In another, all of the function may be applied 
on the server side, in which case a knowledge worker associated with the 
server may initialize the sites for search. 

25 It will also be apparent to one with skill in the art that other modules 

responsible for added function may, if desired, be provided within 
application 139 without departing from the spirit and scope of the present 
invention. For example, a module for sectoring a pre-configured data search 
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and scheduling each sector for execution may be provided within layer 141 . 
In this case, a user may schedule alternate data searches of separate groups 
of URLs. Other lesser controls (not illustrated) may also be provided such 
as edit controls, clear selection, cancel search, and so on. There are many 

5 possibilities. The inventor intends that application 139 represent just one 
simple implementation out of many possible alternative implementations. 

Fig. 8 is a block diagram illustrating intelligent navigation and parsing 
capability according to an embodiment of the present invention. A 
navigation/parsing application 159 is provided for the purpose of navigating 

10 to and parsing data from WEB-based data sources on behalf of a user. 

Application 159 may be considered somewhat analogous to the "gathering 
agent" described in S/N 09/323/598. Application 159 is responsible for 
navigating to selected URLs and extracting data from them for return to 
users. Enhanced capability provided in part by enhanced input data for 

15 navigation and in part by built-in intelligence enables application 159 to 

operate more intelligently and in a more streamlined manner with respect to 
workload. 

Input to application 159 comprises DTD data and site-logic data 
interwoven into an instruction routine that provides instruction for 

20 navigation, log-in (if required), and data parsing. A directional arrow labeled 
DTD/Site-logic illustrates data input. A navigation and parsing sequence 
161 is executed based on input data instruction. Parsing intelligence is 
enhanced by virtue of data reference libraries 163 and 165. Library 163 is 
responsible for enabling text matches and associations. 

25 Library 163 is flexible such that a parsed word may be associated 

with a variety of similar words or phrases. For example, if data is being 
parsed from an investment site quoting stock prices, then the appearance of 
the word portfolio may be equated with not only the exact word, but also 
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with a similar word or phrases known to equate with the word such as 
"stock portfolio", "current portfolio", "view portfolio", and so on. This 
enables a user to approximate the description of the type of data that is 
extracted from a highlighted portion of a WEB page. Moreover, if a WEB 
master changes the description of the data between searches, an intelligent 
parser will still be able to find the data through word and phrase association 
techniques. 

Library 165 contains examples of style variations that may be used in 
the presentation of data on a WEB page. Library 165 enables the parser to 
understand data presented in a variety of styles such as italic, bold, 
underlined, small fonts, larger fonts, text formats, font styles, and so on. In 
this way, a parser may still find the requested data even if a WEB master 
changes the style or format of presentation between data searches. 

In one embodiment of the present invention, successful request 
histories may be compiled and used to enhance parsing and data return. 
Parsing is, in this example, restricted to a highlighted portion or portions of a 
WEB page, wherein the requested data presumably resides. Because of this, 
it is likely that only a few differing types of information will be available in 
the highlighted portion of a WEB page. Therefore, past request records may 
be used in an attempt to eliminate or confirm a data type residing in a 
highlighted section under consideration. This embodiment assumes that a 
current request for data does not register any matching words or phrases 
contained in the data type or in parsing intelligence. 

To further illustrate, assume that there are two different data types 
available in a highlighted portion of a WEB page. If the page is a banking 
page, one of the data sets may be a list of available loans and current interest 
rates. The other data set included in the section may be a list of most recent 
savings account deposits and withdraws. By parsing all of the data in the 
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section, and comparing the data to a previous (successful) routine, it may be 
determined which type of data was previously returned. By comparing the 
previous natural language request to the current one, it may be determined if 
the requests are similar in nature. If a previous request read "return available 

5 loan options and current rates" it can be determined that the loan data did 
match that request. If a current non-registering request reads "send me my 
balance", it may be determined that the current request does not register 
with the system, but it is also not analogous to the previous successful 
request. Therefore, the data set corresponding to the request for loan 

10 information is discarded and the remaining data is returned including the 
account information. 

The above example serves to illustrate adaptive intelligence that is 
provided to navigation and parsing sequence 161. It is assumed herein that a 
user will only select portions of a WEB page where desired data resides. 

15 Therefore, it is likely in many cases that one or only a few types of data will 
be included in a selected portion. This fact makes it easier to determine what 
data will be returned to a user. It is also noted here that all of the data from 
a selected portion of a WEB page is retrieved from a source. Parsing of the 
data after it is retrieved determines which data will be returned to a user. 

20 Data that does not fit a request for that section is discarded. In one 

embodiment of the present invention, all data from a section is returned by 
default if a request cannot be matched to specific data in the section. 

In still another embodiment, a WEB master may change the location 
of data on a WEB page between routine data searches such that it is moved 

25 out of a user's highlighted section of the page. In this case, a routine could 
be performed to find the moved data if the WEB master has retained the data 
structure. To accomplish this, the system compares the old highlighted 
structure with the new structure of the WEB page and matches the 
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structures. If the data contained in the new section matches the current 
request, then a correction is made. 

Application 159 may be executed to navigate to and gather data from 
a single data source or from multiple data sources depending on pre- 
5 configuration. Conceivably, there is no limit to the number of URLs that 
may be included in one executed routine. 

In still another embodiment, application 159 may be enhanced with 
additional enterprise rules to allow for even more intelligent parsing 
capability. For example, in addition to data reference libraries 163 and 165, 

10 which provide intelligence regarding text and style variations, an additional 
rules base may be provided for allowing system 161 to determine logical 
application of certain data-types that are parsed. 

In some instances, data requested by a user may include time 
dependent data that may change or otherwise may not be valid after a certain 

15 period of time or date. One good example of this would be if a user requests 
all ongoing chat events from a plurality of separate chat sites wherein the 
events fall under a general topic or field of entertainment. Application 159 
would navigate as previously described, and system 161 would parse the 
available chat titles at each site. An additional step would eliminate all chat- 

20 event titles or event fields that do not closely match the request thus 

narrowing the field. A subsequent step would eliminate all remaining events 
that are almost over. A next step may eliminate all remaining events that are 
marked for gender or age participation other than what is known about the 
requester. Ultimately, the field is narrowed to those events that match the 

25 request, have agreeable participation requirements for the requester, and 

have sufficient time left in session for optimum participation. As a final step, 
the top 10 or so qualifying events may be selected for the requester based on 
number of participants etc. 
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The above method may be applied to any type of timed live event 
presented on the Internet. Live concerts, live video presentations, live radio 
shows, and many other types of WEB-events may be included. Rules 
governing such events may be compiled and made a part of user profile 
5 information and a rules base added to application 159 may be retrieved from 
that information and therefore will be individual to a requester. There are 
many possibilities. 

Fig. 9 is a flow chart illustrating a semi-structured data retrieval 
process according to an embodiment of the present invention. In step 167 a 

10 user logs into his or her personal portal page. Typically, a user name and 
password is required during step 167 for authentication purposes, although 
in some cases the log-in may be automatic. At step 169 the user invokes 
application 139, which is presented as an interactive tool along with other 
functions in the portal page. Application 139 is used to pre-configure URLs 

15 for data search and return as was previously described. During this step, 
application 139 opens a browser window for navigation. It is important to 
note here that In a preferred embodiment a user pre-configures each WEB 
page while on-line and navigating to each page. However, this is not 
required to practice the present invention. In one embodiment a user may 

20 work off-line if he or she has all of the WEB pages cached in their 
presentable form. 

At step 171, a user navigates to a desired URL for purposes of 
highlighting sections of the page for data retrieval. At step 173, the entered 
URL is displayed in the open window. Using a provided selection tool, a 

25 user then highlights a desired section or sections of a displayed WEB page at 
step 175. A user may highlight one or more sections of a same page. 
Moreover, one highlighted section may contain one or more sets of data a 
user wishes to retrieve. During step 175, a user also types in a data 
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description concerning what type of data is to be returned from the 
highlighted portion of the page. If only one type of data exists in the 
highlighted section, then a description may not be necessary. It is noted 
herein that a user will likely highlight a section larger than a portion just 

5 containing the desired data in case the data is moved slightly within a same 
WEB page between data searches. 

At step 177 a user submits his or her selection and request entries to 
a server application responsible for further processing. Layer 143 of Fig. 7 
represents the above mentioned server application. In this step, a user may 

10 configure many URL sites and data requests associated with the sites and 
submit all of the information collectively by one action. 

At step 179, a DTD is generated for each highlighted portion of each 
URL. DTDs provide instruction to the parsing application as previously 
described in Fig. 7. At step 18 1, DTDs are organized and integrated with 

15 applicable site-logic including any log-in instructions required to access 
WEB sites. The result of this integration is an executable routine and 
instruction template for the navigation and data-gathering system taught in 
disclosure above. After a user submits all of the required data in step 177, 
the process is entirely automated. 

20 At step 183, it is determined whether data results are requested 

immediately (on demand) or whether they are directed to be held for a user 
for later access. If a user requests immediate data return, then a browser 
control immediately executes according to generated instruction at step 191. 
A user may configure and request data from one URL at a time and receive 

25 data while still engaged in requesting data from a next page so as to operate 
in an active session of requesting and receiving data. However, typical 
implementation will be to pre-configure and request data from a series of 
URLs and schedule the data return for a later time. 
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At step 193, data is gathered and results are returned according to 
completed instruction. At step 195 a user receives the resulting data as it 
becomes available. It is noted herein that a user may practice an active 
session of immediate data return upon configuration and data request 

5 submissions. It is also noted herein that a user may complete a configuration 
and request submission process, and set-up a periodic time-table for the 
process to execute. The latter is the more likely and more useful scenario. 

If it is directed that a user have his or her data results held for later 
access, then at step 185 a browser control is invoked for execution of the 

10 request. At step 185 data is found and parsed according to instruction. At 
step 189, data results are aggregated and held for a requesting user. 
Activation of the data-gathering and return process may be delayed 
according to schedule with periodically scheduled return of results. 

It will be apparent to one with skill in the art that the interactive 

15 process described herein may be altered to accommodate a number of 

different user preferences without departing from the spirit and scope of the 
present invention. For example, a user may pre-configure separate groups of 
URLs for data retrieval and cause separate processes to operate according to 
user selected time periods. For example, a user may wish to have all of his 

20 or her account information delivered on a certain day each week while he or 
she gets a news headline summary daily. There are many possibilities. The 
inventor intends that this process example represent just one of many 
possible orders for practicing the present invention. 
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5 

Automatic Proxy WEB-Site/Service Registration 

In another aspect of the present invention, a method and apparatus 
including software is provided for automatic proxy registration to a WEB- 

10 site or service on behalf of portal system subscribers. 

Fig. 10 is a network overview of a communications network 197 
enhanced with automatic site-registration according to an embodiment of the 
present invention. Communications network 197 comprises a data packet 
network (DPN) 199, a portal service domain 205, an ISP 201, and an 

15 exemplary user 203 . Some of the elements that will be described in this 

specification are very similar to elements described in disclosure contained in 
the cross-referenced applications listed under the cross-reference section 
above. However, those similar elements re-introduced in this specification 
are modified or enhanced to practice the present invention. Therefore, 

20 similar elements newly introduced in this specification have new element 
numbers. Analogies are drawn to previous elements throughout this 
specification where appropriate. 

DPN 199 is, in this example, the well-known Internet network and 
will hereinafter be referred to as Internet 199. Internet 199 is analogous to 

25 Internet 13 of Fig. 1 in description and may well be another type of known 
DPN as described in Fig. 1 (Internet 13) above. The inventor chooses 
Internet 199 as a preferred example because of high public access 
characteristic. Internet 199 has an Internet backbone 207 illustrated therein. 
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Backbone 207 represents all of the lines, equipment, and connection points 
that make up the global Internet network including connected sub-networks 
as are known in the art. Therefore, there is no geographic limit to the 
practice of the present invention. The inventor deems that illustration of just 

5 a portion of Internet 199 (illustrated within cloud) is sufficient for 
explanation and disclosure of the present invention. 

Portal service domain 205 (enclosed in dotted rectangle) represents 
all of the equipment and network connections within Internet 199 that are 
hosted by an exemplary company providing portal services. For example, 

10 domain 205 comprises a WEB-server (WS) 217, a database server (DBS) 
219, an instant server (IS) 221, and a navigation server (NS) 223. Each of 
servers 217-223 is network-connected to backbone 207. Moreover, all of 
the above-described servers are interconnected, in this example, by a 
separate data network 206. Network 206 is optional and only represents an 

15 efficient method for facilitating dedicated data and command communication 
between servers and is not required to practice the present invention. This 
example differs somewhat from the example of Fig. 1 wherein portal services 
are hosted by ISP 15. In this example, portal services are hosted within the 
domain of Internet 199 instead. The exact location of service-providing 

20 equipment is optional, as is the description of a hosting company. 

WS 217 is configured as a main portal WEB-server and represents a 
first interface to subscriber/users exercising various portal services. Servers 
219-223 represent separate secondary servers each providing dedicated 
function related to the present invention. For example, DBS 219 is adapted 

25 as a central repository for storing profile data, enterprise data, and summary 
data obtained from external sources within the domain of Internet 199 and 
returned thereto as described in the cross-referenced applications dealing 
with WEB summary gathering. IS 221 is adapted as an order generating 



-55- 

server, which prepares job orders according to user requests, and NS 223 is 
adapted as a proxy navigation server. More detail about servers 217-223 is 
provided below in this specification. 

Illustrated outside of domain 205 are a WS 225 and a WS 227. 

5 WEB-servers 225 and 227 represent data or information servers as are 

known in the art for serving information and enabling services to any users 
registered thereto for purpose of obtaining access to data and services 
therefrom. For example, WS 225 may be a bank server, an investment 
server, an entertainment server, or any other class of servers known in the 

10 art. The same may be assumed regarding WS 227. A separate entity or 

entities other than the one hosting domain 205 in this example, typically host 
servers 225 and 227. 

ISP 201 is configured to provide typical Internet connection services 
as are known in the art. User 203 is an exemplary user, which in this case, is 

15 a subscriber to the portal services available from domain 205. User 203 is 
provided access to Internet 199 through ISP 201. For example, user 203 
operates an Internet appliance, illustrated herein as a personal computer (PC) 
215. PC 2 1 5 is illustrated as having an Internet connection line 2 1 3 
connected thereto and progressing to a modem bank 211 (shown as single 

20 modem icon) of an ISP connection server 209, which in turn is connected to 
backbone 207 within Internet 199. 

In this way, user 203 has access to Internet 199. Internet connection 
line 213 may be a conventional telephone line, an ISDN line, a DSL line, or 
any other known connection technology including wireless connection. PC 

25 215 may be any other type of known Internet appliance capable of 

connecting to and downloading information from Internet 199. In this 
example, it is assumed that user 203 is a subscriber to Internet portal 
services offered through domain 205. Therefore, it is assumed that an active 



-56- 

session is established between user 203 operating PC 215 and WS 217 
within domain 205. WS 217 is, in this example, a portal server adapted to 
serve a portal home page to user 203. 

Also in this example, auto-registration capability is distributed over 
servers 217-223 within domain 205. However, this is not required in order 
to practice the present invention, but merely illustrated as such for purpose 
of discussion and separation of function. In other embodiments, other 
distribution arrangements may be observed. Furthermore, all of the function 
of the present invention may be facilitated on one server. 

WS 217 (portal server) has an instance of site configuration (SC) 
software provided therein. SC is a first part of an auto-registration suite. SC 
software provides an interface to user 203 from which he or she may pre- 
configure WEB-sites for auto registration. Part of that capability includes 
the provision of an interactive tool known to the inventor as "Reg Spy" (not 
shown). The basic function of SC software on server 217 is to allow user 
203 to navigate to and select (using Reg Spy) the proper URLs and forms, 
which will then be used for obtaining registration to a site on behalf of user 
203. 

In one embodiment of the present invention, a plurality of WEB-sites 
may already be configured for auto-registration service and may be 
presented to user 203 at time of log-in to WS 217, perhaps, as part of his or 
her personal home page. This is made evident by illustration of an instance 
of portal host (PH) associated with WS 227. PH more accurately reflects 
that domain 205 already has all of the required site-logic and form data to 
allow a user to auto-register to a service provided by WS 227. PH, as 
illustrated here, could be present in the form of a hyperlink embedded in any 
given WEB-page held in WS 227 that is currently facilitating user 
registration. By clicking on a (PH) hyperlink during normal WEB 
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navigation, user 203 could launch an auto-registration process beginning 
within domain 205. In some cases, however, user 203 may wish to add new 
sites for auto registration. WS 225 represents a server containing such a 
new WEB-site or sites not previously configured by domain 205. 

5 DBS server 219, as previously described, holds profile data, 

enterprise data, and summary data. An instance of database renderer (DR) is 
provided to execute on DBS 219. DR software is adapted to allow writing 
to and parsing from DBS according to need. IS 221 has an instance of 
request generation (RG) software resident therein. RG software is provided 

10 and adapted to generate a machine-readable job-order from information 

submitted by user 203 and from prior information available in DBS 219. IS 
221 formulates a job order, which includes instruction for navigation and 
log-in, if required. The output of RG software is a machine-readable job- 
order that carries instruction for site-navigation and instruction for site 

15 registration purposes. 

NS server 223 is adapted by means of an instance of auto-registration 
(AR) software. AR software is adapted to physically navigate (according to 
provided instruction) to a target site on behalf of user 203, and register user 
203 to the target site or service. AR software performs a significant portion 

20 of auto registration in that it actually submits the data required for site- 
registration on behalf of user 203 and returns accepted user-data back to 
domain 205. Data "gathered" after an auto-registration function includes 
accepted log-in names and passwords to the site. NS software is similar to 
the "gathering agent" described in S/N 09/323/598 except that in addition to 

25 navigating to a WEB-site and retrieving data from that site, auto registration 
sequences may also be performed. 

Total auto-registration capability includes a means for site- 
configuration (SC), a means for converting collected data and pre-known 
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information into a job order (RG), a means for proxy navigation and data 
submission to a WEB-site (AR), and a means for returning successful 
registration data to a data repository for subsequent use (AR, DR). 

As previously described, WS 225 and WS 227 represent WEB- 

5 servers containing URLs invoking a form or forms, which user 203 may fill 
out (populate) and submit for purpose of obtaining services therefrom. In 
addition to registration forms, other forms may be processed by method and 
apparatus of the present invention. For example, purchasing forms, survey 
forms, classified add forms, auction forms, and others make up a list of 

10 possible form types to which the methods and apparatus of the present 
invention may be adapted. 

Auto registration may follow two separate orders. One is that a user 
selects a pre-configured site for registration. The other is that a user pre- 
configures a found site for registration. Assume now that user 203 wishes to 

15 register to receive a service available from WS 225. In this case, WS 225 is 
not pre-configured or necessarily known to domain 205. In order to auto- 
register to a site or service hosted by server 225 user 203 must first pre- 
configure the site. 

In general practice of the present invention, user 203 would first log- 

20 in to WS 217 and establish an on-line session between PC 215 and WS 217. 
User 203 would then invoke SC software, and proceed to navigate to WS 
225 and to the page offering registration for services. Upon arriving at the 
site, user 203 invoking SC software, highlights the required form or forms 
that must be filled for registering to a service or services facilitated by the 

25 target WEB-site, and page keywords identifying the form carrying page to 
the service. This "site data" including form data is transferred to WS 217. 

Once WS 217 has the required site data including the required forms, 
it checks DBS 219 to see if all of the required "submission" information is 
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already available in a user profile to submit for this particular registration 
action. It is noted herein that user 203 may have several stored profiles that 
he or she may use to register to different types or classes of services. In this 
case a user may designate a particular profile for registering to a particular 

5 service as part of the configuration process. Data stored in a profile may 
include credit card information, address information, e-mail information, 
telephone information, age and gender information, monikers (aliases), and 
so on. If a particular item of data is required, but not found in a designated 
profile, user 203 may be prompted by WS 217 to submit the required snippet 

10 of data. 

Of course, auto registration is intended to eliminate or at least reduce 
to a minimum the repetitive data-entry normally required to fill out numerous 
forms at different WEB-sites. Moreover, repetitive submission of user- 
chosen passwords, log-in codes, and user-names for site acceptance or denial 

15 can be eliminated. In a preferred embodiment user-names, log-in codes, 

passwords, and the like are generated and submitted by the auto-registration 
process. This can be accomplished under partial user direction, or it can be 
accomplished completely without user involvement. In the first case, user 
203 may have a list of unused passwords, user-names, and/or log-in codes 

20 that were pre-chosen and stored along with profile information. In the 
second case, such submissions may be automatically generated and 
submitted according to form requirements and site rules wherein the user has 
no knowledge of the data even after successful registration. The second 
embodiment follows a scenario wherein passwords and the like are 

25 optionally managed by the password-all portal service of application S/N 
09/208,740. 

Referring again to Fig. 10, all of the site data is passed to IS 221 
over data network 206 (optional). In another embodiment the data is passed 
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over shared bandwidth on backbone 207. IS 221 is responsible for request 
generation (RG). Applying all of the required site data, navigational data, 
and profile data, IS 221 creates a job-order (not shown) containing complete 
instruction for navigation, form filling, and data return. Applicable user data 
5 is encrypted when transferred over secure socket links (SSL) as is known in 
the art. 

In a preferred embodiment job orders are written in eXstensible 
Mark-up Language (XML), however, this in not required in order to 
practice the present invention. Other suitable mark-up languages may also 

10 be employed. A completed job order is then passed to NS 223 over 

network 206 or backbone 207. NS 223 using AR software executes the job 
order according to instruction. 

NS 223, executing a job order on behalf of user 203, navigates to 
WS 225, in this example, and submits data either directly from DBS 219 

15 where it is stored, or from within the order itself The first case assumes that 
codes are used in the XML order that equate to actual values in DBS 219. 
In this case, the data is not released from DBS 219 until it is requested by 
NS 223 during the form-filling process. The second case assumes that the 
XML order includes the actual values. In this case, the portion of the XML 

20 order containing user information is encrypted before navigation. 

After successfully registering user 203 to obtain services offered by 
WS 225, accepted log-in and any password data is returned to DBS 219 and 
written thereto as part of a new user-site block pertaining to that particular 
WEB-site or service. Such a site may now be included in future data- 

25 gathering and summary processes wherein auto-log-in is possible as 
described in cross-referenced application S/N 09/323,598. 

In a case wherein a site is already known to domain 205 and is 
already pre-configured for navigation and form filling, as is the case with WS 
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227, the process follows a different order. For example, user 203 would 
log-in to WS 217 (portal server) and receive his or her personal portal page 
as described above. User 203 may either select a service hosted by WS 227 
from a presented list of services, or he or she may navigate to the actual 
5 WEB-site where an icon (PH) is visible, such as on a registration page of the 
site. 

In some cases, a user may simply be browsing WEB pages and 
stumble upon a registration icon. By clicking on the icon, or a similar 
representation thereof, while visiting the site or while browsing a list of pre- 

10 configured sites within his or her portal page, the auto-registration process is 
automatically launched from within domain 205. The process is essentially 
identical, except that much of the required data such as site navigation data 
and form data is already known to domain 205. Therefore, several steps 
may be eliminated from the process as a whole. Moreover, a generic XML 

15 order may already exist for services hosted by WS 227 such that only the 

profile data generic to a specific requesting user need be added to the order. 

It will be apparent to one with skill in the art that the method and 
apparatus of the present invention may be practiced in a variety of ways 
without departing from the spirit and scope of the present invention. For 

20 example, sites offering services may be pre-configured for auto registration 
services by domain 205 such as is the case with WS 227. In these scenarios, 
such sites and services may be researched and rated ahead of time as to 
quality of service including dependability, success rate, customer service 
capability, and so on. By performing much of the pre-registration research 

25 generally required of a customer wishing to register for any services, a 
customer may be put more at ease and may be more likely to do more 
business on the Internet. The fact that a third party, which is already trusted 
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by users, performs auto registration extends that credibility to the particular 
site offering the services. 

Still, a user may desire to find and register sites (WEB findings) that 
are not known to domain 205. As part of the service offered by domain 205, 

5 users understand and accept any risks posed by added sites as part of normal 
business. Registration by proxy on behalf of requesting users is possible for 
virtually any offered service that might be obtained through the Internet by 
interactive form. 

Fig. 1 1 is a block diagram illustrating software architecture of an 

10 auto-registration suite 229 according to an embodiment of the present 

invention. Suite 229 represents the server-distributed software components 
of Fig 10 above. As previously described suite 229 may be divided to 
execute on a plurality of machines, or it may be provided on one powerful 
server. In this example, all described components are grouped by layer into 

15 one application or suite 229 for exemplary purpose only. 

Suite 229 has a software layer 23 1, which is provided therein and 
adapted as a site-configuration layer (SC). Layer 23 1 is analogous to SC 
software illustrated on WS 217 of Fig. 10. Layer 23 1 has a portal interface 
module 239 provided therein and adapted to function as a user-interface for 

20 general portal services as well as an interface for services related to auto- 
registration services. For example, a user may first invoke module 239 in 
order to cause display of his or her portal options. 

A registration spy (Reg- Spy) module 241 is provided within layer 
231 and is user-accessible through portal interface 239. Reg-Spy 241 is a 

25 tool that enables a user to navigate to any service-offering site for the 

purpose of highlighting site forms and other associated data that is required 
for successful navigation and registration to a site or service. Reg-Spy 241 
may be used to highlight a main registration form and description, as well as 
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any secondary forms and descriptions required to receive secondary services, 
added services, optional services, or customized versions of main services. 
By default, the auto-registration service of the present invention will only 
register users to main services linked from pre-configured sites. However, a 

5 plurality of services, or options depending from a main service may be 
configured manually for auto-registration if desired. 

A database interface module is provided within layer 23 1 and 
adapted for enabling bi-directional database communication with DBS 219 
of Fig. 10. A profile generation module 245 is provided within layer 23 1 and 

10 adapted to enable a user to create and add a new user profile to a list of 

existing user profiles. Using module 245 in conjunction with module 243, a 
user may also edit existing profiles, or delete existing profiles. In this 
example, modules 241-245 are secondary modules available through portal 
interface module 239, however that is not specifically required in order to 

15 practice the present invention. For example, a user may log-in solely for the 
purpose of editing a profile, in which case, module 245 may be requested 
and presented as a first option after log-in. Similarly, module 241 may be 
requested as a first option after portal log-in. In normal practice of the 
present invention, various options would appear on a user's personal portal 

20 page as previously described. 

Suite 229 has a software layer 233 provided therein and adapted for 
request generation (RG) and activation, as so labeled. Layer 233 provides 
function, which is analogous to the function of IS 221 of Fig. 10. Layer 233 
has an auto-registration module 247 provided therein and adapted as a 

25 software mechanism for initiating a request generation process for 

registration to a particular WEB-site. Module 247 may also be provided 
within layer 23 1 without departing from the spirit and scope of the present 
invention. For example, a number of pre-configured services may be listed 
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and accessible from interface 239 wherein one may be selected and then 
activated to target level by invoking a list-associated module 247 thereby 
launching the request generation process. 

Layer 233 has a database interface module 249 provided therein and 

5 adapted for bi-directional database communication as described above with 
module 243. Within layer 23 3 , module 249 allows access to DBS 219 of 
Fig. 10 for the purpose of verifying that all of the required data is available at 
the time of request generation. It is noted herein that profile data held in a 
user profile is not necessarily configured for insertion to a particular form 

10 according to site rules. Therefore, a base converter module 251 is provided 
within layer 233 and adapted to "convert" profile data to a form acceptable 
to required form fields using the applicable format required by the target site 
at the time of registration. 

Base converter module 25 1 may also comprise several sub-modules 

15 (not illustrated), which are adapted to handle specific types of data. For 
example, age requirements may be handled by a "birthday converter", 
financial payment data may be handled by a "payment converter" and so on. 
Module 25 1 is responsible for formatting available data according to site and 
enterprise rules. As such, input and output dependency tables are employed 

20 as a method of understanding various requirements for data formatting. 

In order for the service in an embodiment of the present invention to 
register a user to a site, it must first obtain all of the service-dependent 
profile fields required for successful registration at a particular site/service. 
To accomplish this, all of the required site-specific forms must be obtained 

25 along with all of the site-specific fields contained therein, as well as the 

specific data-format requirements for each field. This is accomplished during 
site configuration using module 241. 
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An input dependency table is created listing all of the user fields and 
format requirements needed by a particular site for registration. A second 
list is obtained that contains all of the user fields of the input dependency 
table that a user already has stored in his or her profile data table. Such a 

5 table may hold items that are used in different profiles such that the list is a 
compilation of all of the stored data items repeated throughout several 
separate profiles without repeating one of the data items. 

By comparison then, a list of fields missing data is developed if there 
are any. If there are no required fields missing data, a request may proceed 

10 from WS 225 to IS 221. Converter module 25 1 insures the data is properly 
formatted for site-specific rules. If data is missing from a user profile, then 
the user is prompted to supply the missing data. 

The job of converter module 251 is to map user data into a format 
accepted by a particular form. For example, a user profile format for a full 

15 name may read last name, middle name, and first name. This format is 
widely recognized in many formal applications however, some sites will 
require a first name followed by a last name with no space for a middle name 
or initial. Using Reg-Spy tool 241, a user has highlighted the target form- 
field, and the rules that apply. Therefore, at the time of request generation in 

20 layer 233, converter module 25 1 has the required format requirements for 
that specific section of data. When accepting user information for profile 
generation, the service may ask for more than is typically required on most 
forms. In this way, the chance that a user will be required to add something 
after a request generation has initiated is minimized. 

25 Layer 233 has a job-generation module 253 provided therein and 

adapted to write a functional XML instruction order containing all of the 
required data for navigating to and registering a user to a particular service. 
Base converter 251 supplies all of the re-formatted (if required) user-data to 
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module 253 for inclusion into the order. A job order will contain a site- 
navigation template, an auto-login block (if required), and user data or a 
reference to the appropriate user data to submit to site forms required for 
registration purposes. A test module (not shown) may be built into an XML 
order generated by module 253 such that form filing may be rehearsed for 
accuracy before actually submitting the data to a site. Such a test module 
may instead be provided as part of Reg Spy 241 . Once an XML order is 
deemed correct and is ready to execute, it is passed on to a navigation sub- 
system through a navigation interface module 255. 

After data conversion and all other requirements are satisfied, an 
XML job order written by module 253 will resemble the following 
exemplary order. 

<register url=" http://lc2.law5 .hotmailpassport.com/cgi- 
bin/tos.cgi?us=hotmail&_lang=&beta= M > 
<form> 

<action type- , fill_and_submit" actionArg- 'Submit.x M > 

<keywords>Profile Information</keywords> 
</action> 

<field type- n OPTIONS H name="month n > 

<value>03 </value> 
</field> 

<field type^'PASSWORD^M 7 " name= M passwdl"> 

<value>5cacb3cb76ab4e7996aff6fa630412e4</value> 
</field> 

<fieldtype= M OPTIONS" name= M day"> 

<value>3 l</value> 
</field> 

<field type— "TEXT" name= M xage n > 

<value>2 1 </value> 
</field> 

<field type= M OPTIONS M name= M xoccupation"> 

<value>un</value> 
</field> 

<field type— 'LOGIN" sendback=" 1 " name= ,, reglogin , *> 
<value>ji</value> 
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<value>yodleeuser</value> 
<value>ji3 4</value> 
<value>yodleeuser43 </value> 
</field> 

<field type= n PASSWORD" sendback="l" name= n passwd"> 

<value>5cacb3cb76ab4e7996afF6fa630412e4</value> 
</field> 

<field type— TEXT" name= n xfname M > 

<value>Ji</value> 
</field> 

<field type-'TEXT" name= M xlname H > 

<value>Lee</value> 
</field> 

<field type— "TEXT" name-"xzip"> 

<value>94086</value> 
</field> 

<field type="RADIO n name= n xgender"> 

<value>m</value> 
</field> 
</form> 
<form> 

<action type="reset_auto _reg n actionArg- ' "> 

<keywords>someone has already selected</keywords> 

</action> 

</form> 
<form> 

<action type="fill_and_submit" actionArg- 'I Accept"> 

<keywords>MSN HOTMAIL TERMS OF 
SERVICE</keywords> 
</action> 

</form> 

<form> 

<action type- 'reset_auto_reg" actionArg- '"> 

<keywords>Hotmail Registration</keywords> 
<keywords>Sign-In Name contains reserved or ineligible 

word</keywords> 

</action> 

</form> 
<form> 

<action type- 1 success" actionArg- ,H > 

<keywords>Sign Up Successul</keywords> 

</action> 

</form> 
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<form> 

<action type- 'reset_auto_reg" actionArg= HH > 

<keywords>Sign-In Name already in use</keywords> 
</action> 
5 </form> 
</register> 

The exemplary order shown above has been slightly altered in 
indentation for some lines to compensate for page margin. One with skill in 

10 the art, however, will recognize the proper XML format. It is also noted 
herein that values listed in the order do not contain actual data, but coded 
equivalents to the data as registered in DBS 219 of Fig. 10. In this 
embodiment profile data is only pulled when required for submission as 
previously stated. In this way, security is enhanced and the actual order may 

15 be condensed. In one embodiment metadata may be inserted into value 
fields contained in a job order. 

Suite 229 has a software layer 235 provided therein and adapted for 
auto-registration (AR) and data refresh. Layer 235 is responsible for 
navigating to a target WEB site and submitting registration information to 

20 the site on behalf of a requesting user. Upon successful registering, layer 

235 is also responsible for the return of confirmation and log-in information 
to a user and database 

Layer 235 has a navigation engine 257 provided therein and adapted 
to navigate to a target WEB-site based on navigation instruction contained 

25 in a job order generated in layer 23 5 . Navigation engine 257 may navigate 
to any site or series of sites specified in the associated job order. Engine 257 
also performs auto-log-in procedures when required. A parsing module 259 
is provided within layer 235 and adapted to parse information from selected 
portions of WEB pages during navigation. Therefore, module 259 works in 

30 conjunction with and may be a part of engine 257. 
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It is taught in the cross-referenced application entitled "Method and 
Apparatus for Retrieving Information From Semi-Structured, WEB- 
Based Data Sources'% that a parsing function parses all data from user- 
highlighted sections or blocks of data contained in target WEB-pages from 
which meta-summaries will be compiled. The parsed data is compared to 
user-input data regarding the nature of the data request. When parsed words 
match keywords contained in the request, the associated data is returned. 

Parsing module 259 operates in much the same way in that it looks 
for page keywords, and form requirements highlighted by a user during pre- 
configuration. Once a page and section (form) has been identified, 
registration action continues as specified by the job order generated in layer 
233. A database interface 261 is provided within layer 235 and adapted to 
allow bi-directional communication to DBS 219 of Fig. 10. In this way, the 
appropriate data may be ordered for submission. 

A data writer module 263 is provided within layer 235 and adapted 
to transfer the appropriate data into the appropriate form fields in the format 
required by the particular form. At this point, a completed form is submitted 
to a service-hosting site. In some cases, chosen user-names, log-in codes, 
etc. will not be accepted by a site. It may be that another user has already 
chosen a particular name. In this case, a retry attempt is initiated using a 
different value either generated by the service, or pre-chosen by a user as 
previously described. 

A data return module 265 is provided to return successful 
registration information including user notification thereof and record of 
successful and accepted values submitted for future log-in purposes. In 
some cases, accepted values may be immediately used by the service to log- 
in on behalf of a user and to obtain data from the site for a user if directed to 
do so by XML order. 
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Suite 229 has a database refresh layer (DBS) 237 provided therein 
and adapted to accept return information from layer 235 for the purpose of 
recording the information for future use. A database filer module 267 is 
provided within layer 267 and adapted to create a new member item for user 

5 203 (Fig. 10) and to write the returned data thereto. In this way, the new 
site is included in a list of user-registered sites for data gathering and 
summary presentation taught in the cross-referenced applications. 

A data validation module 269 rechecks all data written into DBS 219 
(Fig. 10) and supplies any new data to an input dependency table described 

10 previously. In some cases, some user-supplied data will not be valid after a 
successful registration. For example, if a phone number or other temporary 
information is supplied in conjunction with registration to a service, it may 
be deleted after it is no longer needed for registering. One example would 
be that of a temporary site registration. In this case all of the new data 

15 supplied for use with a temporary site registration may be purged from DBS 
219 after the time period allotted for the service has expired. Such a service 
may be a limited free period of technical support for a purchased product or 
the like. 

A user notification module 267 is provided within layer 237 and 
20 adapted to notify a user upon successful registration and in some cases failed 
registration attempts. It may be that a site disqualifies a particular user from 
registration based on information such as credit rating or some other criteria. 
In this event, a notice would be sent to the user. A user presentation module 
273 is provided and adapted to present any summary or refresh data to a 
25 user if it was requested before registration. Such data may be returned along 
with registration confirmation and log-in data. Module 273 is also used 
during normal summary gathering operations after registration and inclusion 
of the target site into a user's list of registered sites. 
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It will be apparent to one with skill in the art that the software 
components contained in layers 23 1-237 of suite 229 may vary in number 
and description without departing from the spirit and scope of the present 
invention. For example, instead of multiple database interfaces, one database 

5 interface may be provided for a suite 229 that is running on one server. 

Moreover, layer 235 may comprise more than one of each described function 
for situations wherein an XML order is split or distributed among several 
navigation, auto registration, and data gathering applications, combined to 
define "gatherers" as termed by the inventor. An example would be that of a 

10 single XML order containing a plurality of URL sites and registration 

requirements for several of the included sites. Separate gatherers may be 
used to execute several actions contained in the order. The inventor intends 
that the example presented herein represent just one possible software- 
architecture that may be used to practice the methods of the present 

15 invention. 

As previously described, the layered structure illustrated herein with 
respect to layers 231, 233, 235, and 237 and components represented therein 
may be distributed in parts over various servers, or contained as one 
application running on one machine. There are many possibilities. 

20 Fig. 12 is a process flow diagram illustrating various process steps 

for auto-registration to a site and receiving data from the site according to an 
embodiment of the present invention. At step 275, a user logs-in to a portal 
server to obtain portal services. In this step a portal page is downloaded to 
the user. It is assumed in this example that all site pre-configuration is 

25 complete and all data is available for navigation and registration purposes. It 
may be that the user is adding a new site or sites that are not pre-known to 
domain 205. It may be that site or sites selected by a user are pre-known to 
domain 205. In some instances, it may be a combination of the above. In 
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case of any of the above conditions, a user invokes an auto-registration icon 
at step 277. Profile selection, as described above, is part of the pre- 
configuration process and therefore, not represented in this process flow. 

In one embodiment a separate registration icon is associated to pre- 

5 configured WEB-sites (one per) appearing in a list of service-offering sites 
on a user's portal page. In another embodiment one registration icon is 
invoked after a user has selected more than one service-offering site for 
registration. In still another embodiment, a user may come across such an 
icon while normally surfing the Internet, at which time he or she may invoke 

10 it to launch an automated registration process. 

At step 279 the portal server of step 275, also termed a WEB-server 
accesses a database to check if all of the information about the user is 
available. It is assumed in this example, that all data is available. If some 
data were not available, a user would be prompted to submit it. At step 281 

15 all user profile data and acquired site data is verified as authentic. In this 

step, codes may be assigned to stored data for latter retrieval based on such 
codes. At step 283, user data is converted to site data with respect to any 
format required by site-specific form-fields. At step 285, an XML order is 
generated based on all required data to complete a proxy navigation and 

20 auto-registration process. 

At step 287, the job order generated in step 285 is deemed complete. 
This step may include data verification and a self-test sequence to insure that 
all of the user data can be correctly mapped into the appropriate form fields. 
If an error occurs during a self-test sequence, then a user is notified of the 

25 error and an attempt to correct the error is initiated. 

Once a job order is deemed complete, it is passed to a navigation 
sub-system in step 289. The navigation system receives and executes the job 
order according to instruction. At step 291, a target WEB-site is accessed 
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according to navigation instruction and page keywords. Page keywords are 
used to verify the exact page containing the required form for form filling. 

In one embodiment part of the job order described above contains a 
DTD template interwoven into site logic as described in Fig. 8 above. Using 
5 this method allows a form to be located based on HTML data-structure 
matching. The target form is highlighted during pre-configuration and a 
DTD is produced for that section and for the URL wherein the section 
resides. 

At step 293, a target form is populated with the appropriate user data 

10 and submitted. This is accomplished according to the action portion of the 
job order. At step 295 , the registration attempt of step 293 either succeeds 
or fails. If in step 295, a form is accepted, then in step 297, the appropriate 
data and confirmation is obtained and returned. 

If in step 295 the registration attempt fails, an attempt to determine 

15 the reason for failure is initiated. In this step, notification may be sent to a 
user explaining the given reason for failure. It may be that the user just does 
not qualify for registration to the target site or service. It may be that an 
error has occurred with respect to data submitted such as a credit card 
number is invalid or expired. In most cases however, failure on a first 

20 attempt will likely be the result of another user already possessing a 
submitted password, user-name or log-in code. 

If a failure notice is displayed by a target service to the navigation 
system, it may be parsed for content with notification sent back to a user. In 
this case, a user may be required to update his or her selected profile with 

25 correct data, or select an alternate profile and re-initiate the process. 

If the failure notice involves submitted passwords or the like already 
being taken, a re-try using new data is attempted by default. This is 
represented by step 299. This step may be repeated many times as new data 
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is obtained to replace data rejected by a site. As previously described, user- 
names, passwords, and log-in codes may be supplied in the form of a list 
selected and approved by a user, or may be generated at the time of form 
population. In step 301, registration succeeds and in step 303, the accepted 
password and log-in data along with confirmation data is returned to a user. 

It will be apparent to one with skill in the art that the process 
described herein may contain additional steps and sub-steps without 
departing from the spirit and scope of the present invention. For example, 
step 291 may contain a series of sub-steps such as parsing, structure 
matching, and so on. As well, processes related to registration error, user 
notification thereof, data correction and re-submission may be tailored 
somewhat based on the type of error communicated. 

The method and apparatus may be practiced with a wide variety of 
interactive forms other than site registration forms without departing from 
the spirit and scope of the present invention. 

API Software Bundle 

It was described in the background section that a truly automated 
navigation system requires various APIs in order to extend functionality of a 
proxy browsing application with a variety of Java-based programs, known to 
the inventor. It is intended by the inventor that such an enhanced browser 
application can perform navigation, authentication, and data downloads on 
behalf of a user without active input by that user. Such an application is 
spawned and controlled within the navigation system such that a spawned 
instance performs solely on machine-readable instruction language. 

Fig. 13 is a block diagram illustrating an overview of application- 
program-interface (API) and control software bundle 305 according to an 
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embodiment of the present invention. Software bundle 305 incorporates two 
main components. These are a Web-browsing application 306, termed a Y- 
browser by the inventor, and a software control application 321 termed a 
robot controller. Y-Browser 306 represents an instance of proxy browsing 

5 software capable of fully automated function and taking its instruction from 
machine-readable language. Controller 321 manages multiple instances of 
Y-browser 306 although only one instance is shown in this example. 

Y-browser 306 contains a plurality of APIs for integrating browser 
306 to a plurality of functional Java-based programs, which are not 

10 illustrated in this example, but which are described below. Each API 

described herein is categorized according to function with each controlling a 
plurality of Java-based functions, which may be thought of as extensions to 
browser application 306. For example, navigation API 307 is provided 
within browser 306 and adapted to provide automation to functional 

15 programs that perform such as auto-login and authentication, hyperlink 

invocation, form filling and submission, data downloading, and the like. A 
statistic collection API 309 is provided within browser 306 and adapted to 
provide automation for programs designed to return statistical information 
for the purpose of monitoring, timing of operations, and other like functions. 

20 Search API 3 1 1 is provided within browser 306 and adapted to 

provide automation to functional programs that perform a variety of search 
operations such as obtaining a data-structure tree of a particular web page, 
often referred to as a document object model (DOM). Other operations 
include searching for specific patterns on a web page, searching for an image 

25 in a web page, searching for tables containing text as a row or cell element, 
and so on. 

Utility API 3 15 is provided within browser 306 and adapted to 
provide automation to functional programs that perform duties such as 



-76- 

parsing date functions displayed in numerous formats and returning such 
functions according to an ordered format, parsing money functions displayed 
in numerous formats and returning such functions according to an ordered 
format. API 315 also provides automation to various encryption and 

5 decryption utilities. An error-recovery API 3 1 7 is provided within browser 
306 and adapted to provide automation to a variety of programs designed to 
recover errors or tolerate faults. For example, one such program monitors 
the loading time of a web page and adjusts a timeout interval if necessary. 
Also, error recovery programs are provided for such as retrying auto login 

10 and other navigation functions if the failure is a first result of a code first 
attempt. 

Robot controller 321 provides management and instruction to 
browser 306 as described above. For example, controller 321 controls the 
number of instances of browser 306 that are running and any given period of 

15 time. Controller 321 continually monitors the behavior of instances of 

browser 306 and looks for suspicious behavior such as erratic performance. 
If a particular browser application 306 does not respond or return status for 
more than a set time it will be terminated, and any new instance will be 
spawned by controller 321. 

20 One with skill in the art will recognize that there may be more APIs 

provided within browser 306 than are illustrated herein without departing 
from the spirit and scope the present invention. The inventor has chosen to 
illustrate just five of the more important APIs with regards to automating 
function and in some cases, providing additional function. The Java-based 

25 programs that were generally described in this example may be assumed to 
be part of the normal function of browser 306. Controller 321, which is a 
software application, is intimately integrated with browser 306 and all of its 
APIs. It is noted herein that APIs referred to in this specification are 
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intended to provide automated extensibility to browser 306 for accessing and 
utilizing the many Java-based routines that are used during navigation on a 
network. In this regard there are many possibilities for automating routines 
specific to a browser as well as interfacing with and providing automation to 

5 many external Internet-based applications as well as new routines and 
applications which are not conceived yet in the prior art. 

Fig. 14 is a block diagram illustrating function of navigation API 307 
of Fig. 13. Navigation API 307, as described above, is responsible for 
providing automation to the many functions used in Internet navigation. A 

10 hyperlink invocation module 325 is provided and represents a Java-based set 
of routines for automatic invocation of such as web page anchors, embedded 
links to other web pages, image links, interactive windows, and other types 
of multimedia hyperlinks. Module 325, as one with skill in the art will 
recognize, is defined by function to the extent of programming. For 

15 example, a Java routine for invoking a link to an alternate web page is a 
separate routine or string from one for invoking an image on a web page. 
However, many such routines may be included within module 325. The 
exact function of module 325 will, of course, depend on the machine- 
readable instruction, which is part of a job order being executed by the 

20 browser application (306) described in Fig. 13 above. API 307 then, 

emulates all user input actions, which would normally be associated with 
manual browsing. Thus, it can be seen that API 307 provides automated 
extensibility to browser 306 (Fig. 13) when executing module 325 according 
to any existing instruction that is part of a running job order. 

25 The relationship described above is true with all browser functions 

that would normally require some user interaction. For example, a site- 
access module 329 is provided and represents a plurality of Java-based 
routines for accessing a web site. Such routines may include an auto login 
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sequence, and authentication routine, a display frames sequence, an ignore 
frames sequence, and so on. It is important to note that functional modules 
such as 325 and 329 are used typically in a logical order. Therefore, module 
329 would be invoked before module 325 when accessing a web page. 

5 Furthermore, depending on instruction, functional modules may be 

alternately used to perform given functions in a stated order as directed by a 
running job order. 

A form-filling module 327 is provided and adapted to enable various 
interactive forms to be populated with data. Such forms could include 

10 registration forms, purchase-order forms, software download forms, and the 
like. Data for filling forms, of course, are part of the running job order. In 
one embodiment such data may be accessed during a pause in a running job 
order. A form submission module 328 is provided and adapted to invoke 
submission of an interactive Web form upon completion thereof. 

15 It will be readily apparent to one with skill in the art that there may 

be many more functional modules provided and interfaced to browser 306 
(Fig. 13) by virtue of navigation API 307 then are illustrated in this example. 
The inventor intends that the functional modules 325 through 329, illustrated 
are exemplary only. Modules 325 through 329 represent just a few examples 

20 of many possible functional modules representing functional Java-based 
routines that may be executed from instruction contained in a job order. 

Fig. 15 is a block diagram illustrating function of statistic-collection 
API 309 of Fig. 13. Statistic-collection API 309, hereinafter referred to as 
stat 309, is provided to enable automation to various Java-based routines 

25 having to do with error correction and recovery. A request calculation 

module 33 1 is provided and adapted to a number of requests existing in any 
given navigation session. Statistical information such as this may help to 
predictably estimate a time period representing the duration of a particular 
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session. A numeric-processing module 329 is provided and adapted for the 
processing of various numbers related to certain states of browser 306 (Fig. 
13). For example, it may be desired to monitor the data rate of data 
download from a particular web page by a particular instance of Y-browser. 
An instance-monitor module 327 is provided herein and adapted to monitor 
function of the immediate instance of Y-browser. Such functions as 
response time, length of spawn-state, ratio of execution to error rate, and so 
on. 

In this particular example, modules 327 through 33 1 report browser 
status back to controller 321 of Fig. 13. Controller 321 in return manages 
browser 306 (Fig. 13) according to feedback. It will be apparent to one 
with skill in the art that certain monitoring and statistic-collecting functions 
may help streamline a proxy-browsing system as a whole and as practiced on 
a network on behalf of many users. The exact modules used, and which 
ways there may be integrated for obtaining and returning statistical 
information well, of course, depend on programming preferences. There are 
many possibilities. 

Fig. 16 is a block diagram illustrating function of search API 3 1 1 of 
Fig. 13. API 3 1 1, as described above, is responsible for providing 
automation to a plurality of disparate search functions. A DOM access 
module 333 is provided herein adapted to access the data structure 
associated with a particular web page. Such a data structure will be 
representative of how all data is represented on the given web page. This 
technique is used to aid in searching for text that is repetitively associated 
with specific parts of a data tree. A pattern-search module 335 is provided 
and adapted to search for repetitive patterns embedded within Web pages. 
An image-search module 337 is provided and adapted to perform the process 
of seeking out and identifying images within Web pages. A table-search 
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module 339 is provided and adapted to perform the process of seeking out 
and identifying text tables within a Web page. Still other search modules 
may be provided and adapted to perform other types of searches. For 
example, a search application known to the inventor utilizes secondary 
search functions that may be embedded within a web page thereby launching 
a second search with the parameters used in the first search. 

It will be apparent to one with skill in the art that modules 330-339 
may be programmed to cooperate with one another without departing from 
the spirit and scope of the present invention. For example, instructions for 
invoking a wide variety of functional modules illustrated in this example and 
in the previous figures may be provided as one interleaved instruction (job 
order), which may be provided through robot controller 321 of Fig. 13, or 
may be communicated in another way to Y-browser 306. 

Fig. 17 is a block diagram illustrating function of utility API 3 15 of 
Fig. 13. As previously described above utility API 315 is provided to enable 
automated function of modules designed for manipulating, restructuring, and 
returning data in proper formats. A data parsing module 341 is provided and 
adapted to parse data found embedded in a particular web page. A data 
conversion module 343 is provided and adapted to convert or restructure 
applicable data for return to a user. Module 341 is used to parse date 
functions, money functions and other numerical representations that may be 
presented in a variety of formats. In this example module 341 is represented 
as a single module capable of multiple functions. In actual practice, a variety 
of sub-modules not shown may be included within module 341, the sub- 
modules responsible for parsing data displayed in various formats and 
returning the data to a user in a requested format. Other functions may be 
included within utility API without departing from the spirit and scope the 
present invention. For example, encryption/decryption programs known to 
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the inventor may be included as functional programs that are executed in an 
automated fashion at appropriate sequences during navigation and data 
transfer operations. 

Fig. 18 is a block diagram illustrating function of error-recovery API 

5 317 of Fig. 13. API 3 17, as previously described, provides automated 
functionality to Java-based programs that deal with monitoring function, 
failure detection, and other types of error-recovery operations. A dialog- 
intercept module 345 is provided and adapted for intercepting and utilizing 
error messages that would normally be sent to a user operating a manual 

10 browser. Module 345 disseminates such error messages and then initiates an 
appropriate operation or operations for correcting the error state or states 
defined by the particular message. A failure-detection module 347 is 
illustrated and adapted to detect operation-sequence failures such as failure 
to Log-in, failure to submit form, failure to load page, and many other types 

15 of operation failures. A time-out monitor module 349 is illustrated herein 
and adapted to monitor the amount of time it takes to perform certain 
operations such as loading a web page. For example, if a Web page is taking 
a particularly longtime to load, module 349 may report the delay and may, 
and some instances, adjust the time-out period in browser 306 to allow more 

20 time for loading Web pages. Data reported back by error detection 

programs is used to make adjustments and/or to attempt to correct initial 
error states. 

Will be apparent to one with skill in the art, that there may be many 
more error reporting or detection modules than are illustrated in this 
25 embodiment without departing from the spirit and scope the present 

invention. The inventor chooses to illustrate three such modules and deems 
these are sufficient for the purpose of explanation of the present invention. 
There are many possibilities. 
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The APIs and associated programs described above share a 
relationship that is one of integration with certain other APIs and programs. 
For example, an entire navigation sequence performed on behalf of the user 
they contain many user requests covering a plurality of Web sites. A running 

5 job order contains all of the instructions required for invoking and executing 
all of the required modules for successfully completing the order. 

The described programs are, in preferred embodiments, integrated 
into browser application 306 of Fig. 13. Each described API provides the 
functionality for integrating the described programs with the instruction 

10 mechanism controlling a navigation sequence. In addition, each described 

API may be further broken down into smaller APIs under a same class of the 
APIs. For example, search API 3 1 1 may be broken down into smaller search 
APIs that provide automation and functionality to certain and specific data- 
search operations. Statistic-collection API 309 may be broken down into 

15 smaller APIs, which provide automation and functionality to a variety of 
statistic-collection programs. 

It will also be apparent one with skill in the art, that in some 
instances, an API will simply integrate known browser functions to an 
automated instruction set such that a user's input is bypassed. The software 

20 bundle of the present invention accomplishes this in addition to providing 

unique functionality to browser 306 by interfacing unique programs with an 
automated functional set of instructions (job order). In this way, many 
complex tasks may be performed on behalf of a user in a truly automated 
fashion from beginning to end. 

25 Fig. 19 is a block diagram illustrating a robot controller 321 

according to an embodiment of the present invention. Controller 321, as 
earlier described, provides management and control to a plurality of running 
instances of Y-browser. Controller 321 is a software application that is 
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capable of spawning and terminating instances of browser 306 (Fig. 13). 
Controller 321 may, in some embodiments, also provide the instructional 
sets for each instance of Y-browser spawned to perform navigation and 
functions according to the instruction sets. A Y-browser instance-control 

5 module 35 1 is illustrated herein and adapted to provide spawning and 

termination control to controller 321 with regards to instances of browser 
306. Module 351 may also be enabled to stall the particular instance or 
instances of browser 306. A status poll module 353 is illustrated herein and 
adapted to poll instances of browser 306 for current status information 

10 regarding respective navigation sequence. Such status results may include, 
but are not limited to, what operation in a sequence of operations is currently 
being executed, whether frames are enabled or not, whether or not functional 
codes, which may enhance browser function, have been downloaded from 
any particular web pages, and so on. 

15 A behavior-monitoring module 355 is illustrated herein and adapted 

to enable controller 321 to monitor behavior of browser instances and to 
detect suspicious behavior. Such behavior may include but is not limited to, 
automated spawning of multiple instances, excessive timeouts, lack of proper 
controls for viewing or downloading certain content, and so on. A load- 

20 detection module 357 is illustrated and adapted to report back to controller 
321 data related to current CPU load of a connected processor or processors 
hosting instances of browser 306. Load data indicates, for example, the 
amount of total cache memory available for current operations, maximum 
capacity for spawning instances of browser 306 per processor, and so on. 

25 Load data may also indicate areas of memory that may be purged of old data 
that has already been transferred to users mortuary repository on behalf of 
users. 
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Robot controller 321 may be provided as a centralized control 
application for controlling multiple instances of browser 306 with such 
instances operating on multiple processors. In another embodiment 
controller 321 may be provided as an individual controller bundled with an 

5 individual instance of browser 306. A software bundle comprising an 
instance of browser 306, APIs 307-3 17, and associated Java-based 
programs, which were described as modules in this specification, may 
include a standalone instance of controller 321 such that controller 321 
spawns and controls a plurality of browser instances within a single bundle 

10 running on a single processor. In another embodiment more than one 
software bundle residing on separate processors may share a centralized 
instance of controller 321 running on yet another processor. In this 
embodiment, a single controller 321 may be adapted to control several 
software bundles executing on respective processors. 

15 As previously stated, a main goal of the present invention is to 

provide a fully functional and truly automated navigation system that may be 
spawned and executed to completion based on machine-readable instruction. 
In a preferred embodiment instruction sets (job orders) are provided to each 
software bundle through a controller 321 responsible for those software 

20 bundles. 

One with skill in the art will recognize that individual modules 
described herein as Java-based programs are included within each bundle 
along with an instance of browser application and associated APIs. 
However, this should not be regarded as a limitation of the present 

25 invention, as APIs may also be used to provide automated functionality to 
programs based externally from browser application 306. It will also be 
recognized that many functional modules are inherent in every browser 
application such as browser 306 as are known in prior art browser 
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applications, but require human intervention to successfully operate and 
execute them in the prior art applications. 

By virtue of the various APIs described in this specification, modules 
may be fully automated and executed from a machine-readable instruction 

5 set. It should further be recognized that many functional modules described 
in this specification are novel over prior art and provide enhanced browser 
functionality not available in prior art. It is noted herein, that many such 
modules were fully described in co-related cases referenced in the cross- 
reference section of this specification as well as in other applications filed by 

10 the inventor, which are not listed or referenced in this specification. 

Provision of a software bundle of the type described in this 
specification provides for the first time a fully functional network-navigation 
system that may be spawned, executed to completion, and terminated in a 
truly automated fashion without requiring intervention of a user or any other 

1 5 human facilitation. 

The method and apparatus also may be practiced in a language and 
platform independent manner, and be implemented over a variety of 
scaleable server architectures. 

20 Automated Navigation Application 

According to one aspect of the present invention, an automated 
navigation application is provided for enabling limited automation and task- 
25 performance functionality to desktop navigators. Such an application allows 
a user to log on to passworded websites and to access data with minimal or 
no user interaction. The methods and apparatus of the present invention are 
taught in enabling detail below. 
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Fig. 20 is a block-diagram illustrating a basic automated navigation 
sequence according to an embodiment of the present invention. Navigation 
sequence 362 represents a very basic and finite navigation sequence that may 
be programmed using or into a desktop browser application. Sequence 362 
may be executed by a one-click action initiated by a user. Sequence 362, in 
this example, comprises only 3 basic operations. 

A first operation requires one click by a user for initiating navigation 
sequence 362. This action is illustrated logically herein by one of a 
triangular pattern of connected circles representing sequence 362. The circle 
just described is labeled click icon and has a function notation 363 associated 
therewith and labeled "User Executes Sequence". In a preferred 
embodiment of the present invention, an execution icon is created as a result 
of the creation of sequence 362. The execution icon, once created, may be 
provided as an addition to a browser interface, such as in a tool-bar section 
or as part of a drop-down menu. In this embodiment, a single icon is 
associated with a single navigation sequence and functions as an initiator of 
the sequence. 

A second operation, which is automated, resulting from execution of 
a sequence icon is navigation itself. This operation is illustrated herein by a 
portion of the triangle of connected circles labeled navigate and associated 
with a functional notation 359 labeled "Navigate to Desired Site". In this 
very basic example, navigation comprises navigating to a single site (URL) 
hosted on the operating network. 

A third operation, also automated, commencing after successful 
navigation is represented logically by a third circle of the illustrated triangle 
labeled population and associated with a functional notation 361 labeled 
"Enter Dialog For Interaction." This operation represents a specific task 
performed for site access to a preprogrammed site. 
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As can be seen in this example, sequence 362 represents the most 
basic of automated navigation sequences. In actual practice however, a 
navigation sequence such as sequence 362 may be much more complex 
encompassing navigation and access to a plurality of sites where an 

5 automated interaction may be performed. Such automated interaction may 
include, but is not limited to, automated log-in, automated population of 
electronic forms, submission of such forms, performing downloads, and 
performing specific site-hosted functions such as viewing slideshows, playing 
multimedia applications, and other types of interactions. 

10 Navigation sequence 362 is enabled by an instruction file (not 

shown), which may be created by a user through recording a manual 
sequence wherein all the desired actions are first manually performed, or by 
creating an instruction file using a machine-readable language that may be 
understood by the browser application through an application-program- 

15 interface (API). More detail regarding the methods and utilities required to 
create and execute an automated navigation sequence are described later in 
this specification. 

Figs. 21a through Fig. 21 d are exemplary plan views of a PC user's 
display screen as may be displayed during an automated navigation sequence 

20 according to an embodiment of the present invention. Referring now to Fig. 
21a, a rectangle representing the physical boundaries of a browser-display 
interface is illustrated and labeled with the element number 365. A sequence 
icon 366 is illustrated within display-interface 365. Icon 366 is a sequence- 
execution icon created and installed within interface 365 as a result of 

25 completion of an associated navigation sequence. In this example, icon 366 
initiates execution of a navigation sequence that is associated with a users 
on-line banking institution. More specifically, icon 366 executes a 
navigation sequence that checks the current balance of the savings account 
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belonging to the user. As such, icon 366 is labeled savings and has a $-sign 
included thereon as part of the icon identification. Such labels, as just 
described, may be created by a user during creation of navigation sequences 
and applied to custom icons such that specific navigation sequences are 
5 easily identifiable. Labels may include text and graphics symbols as 
illustrated herein. 

Referring now to Fig. 21b, display-interface 365 exhibits, in this case, 
an exemplary Internet address WWW.MYBANK.COM, which is labeled 
with the element number 367. Address 367 is the network location of the 

10 web site to be accessed during the navigation sequence executed by initiating 
icon 366 in Fig. 21 a. Address 367 appears in the navigation-address field 
within display-interface 365 as it would during a normal manual sequence. 

Referring now to Fig. 21 c, display-interface 365 is in the process of 
displaying an authentication window for enabling user-access to WWW. 

15 MYBANK.COM. A typical authentication form, labeled herein with element 
number 368, includes a field for entering a user name, a field for entering a 
password, a submit icon, and a cancel icon. Form 368 is automatically 
populated and submitted during the automated navigation sequence executed 
by icon 366 of Fig. 21a, 

20 Referring now to Fig. 21 D, display-interface 365 is displaying a 

result page resulting from successful authentication represented in Fig. 21 c. 
A portion of this resulting page comprises a welcome message and an 
indication of current balance of a users savings account. Therefore, the goal 
of the user-created navigation sequence executed by activating icon 366 of 

25 Fig. 21 a is to navigate to and display a current balance of a particular 

savings account. It is noted herein, that account balance 369 may simply be 
included with other account balances and information provided on a single 
web page. Moreover, a web page containing personal account information 
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will have a location address extended from WWW.MYBANK.COM such as, 
perhaps, WWW.MYBANK.COM/AUTH/PERSNLINF0. 

It will be apparent to one with skill in the art that a navigation 
sequence such as the one executed by icon 366 of Fig. 21a may contain 
navigation functions and task-performance functions that are associated with 
a plurality of electronic information pages associated with a single site or, 
with a plurality of electronic information pages that represent main pages 
and sub pages hosted by a plurality of sites without departing from the spirit 
and scope the present invention. Therefore, a single navigation sequence 
may be programmed to navigate and perform tasks at multiple sites or at 
multiple pages hosted by a single site in an un-interrupted fashion from 
execution to end of the sequence. Furthermore, a navigation sequence may 
be executed during an open browser session at any point in the process thus, 
interrupting a manual session for purpose of performing an automated 
navigation sequence including automated login and limited task performance. 

In the execution of an automatic navigation sequence according to an 
embodiment of the present invention it is not necessary that intermediate 
steps be displayed. In a preferred embodiment the intermediate steps, here 
labeled 21b and 21c, are not displayed, and take place entirely transparently 
to the user. The user clicks icon 366 and the result is displayed 

Fig. 22 is a block-diagram illustrating a functional relationship 
between browser-interface display 365 of Figs, 21a through 21 d and 
navigation-instruction files stored on a user's PC according to an 
embodiment of the present invention. Interface display 365 is as previously 
described a desktop browser interface. A separate window 375 is illustrated 
within interface 365 and represents a user-invoked window containing a 
plurality of automated navigation icons. These icons are listed from top to 
bottom as an icon 379 labeled Savings Account, an icon 381 labeled My 
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Stocks, and icon 383 labeled Credit Card, and an icon 385 labeled Airline. 
Each icon 379-385 is an execution icon associated with a created navigation 
sequence as was described with respect to icon 366 of Fig. 21a. In this case, 
the four illustrated icons are presented in window 375 as a result of an action 
5 performed by a user such as clicking on an option from a pull-down menu. 

A recording function 387 is provided within interface 365 and 
adapted to enable a user to record a manual navigation sequence including 
any manual actions performed by the user with respect to logins, downloads, 
hyperlink invocation, and other typical interactions. Within recording 

10 function 387, a begin function 389 is provided along with an end function 

391. In a preferred embodiment of the present invention, recording function 
387 is employed by a user to create and instruction file, which defines a 
specific navigation sequence. For example, by invoking function 389 
(Begin), a user may designate the start of an automated instruction. The 

15 instruction file is defined by subsequent user navigation. When a user 

finishes with a manual navigation sequence, function 391 is invoked for the 
purpose of designating an end-point to a specific instruction file defining the 
sequence and being created as a result of recording. 

Windows 387 and 375 may be floating windows, which remain 

20 visible within interface 365 during normal network navigation. Further 
illustrated, in this example, is a user PC 374 having a display monitor 373 
and a processor 375, Interface 365 is logically associated with display 
monitor 373 by a dotted line. Therefore, it may be assumed that interface 
365 is displayed on monitor 373 in this example. A hard drive 393 is 

25 logically illustrated and associated with processor 375 by a dotted line. Hard 
drive 393 may be a typical drive C, or a removable drive such as a Zip drive 
or a floppy drive. A plurality of the instruction files, listed herein as 
instruction files 1-4, are logically illustrated herein as resident on drive 393. 
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Instruction files 1-4 are associated by design and function with icons 379- 
385. 

In a preferred practice of the present invention, a user creates 
automated navigation sequences by first opening interface 365 while 
5 connected and in session on an applicable network such as the Internet 
network. Function 387 is then invoked by the initiating user. Recording 
function 387, as previously described, may open as a floating window. 
Window 387 may be preceded by an option available from a drop down 
menu, or by an interactive icon present within interface 365. The invocation 

10 of either of those produces window 3 87. 

To initiate creation of an automated navigation sequence, a user 
invokes begin function 389 and commences a manual navigation sequence. 
Each action committed by a user during the manual sequence is recorded. In 
this way, site mapping is recorded along with the location and nature of 

15 exerted hyperlinks. Other actions and parameters such as authentication 
procedures, purchase order procedures, embedded media invocations and 
the like are similarly recorded as they occur. In addition, in some 
embodiments of this invention, periods of time utilized for the purpose of 
reading text, and viewing or listening to invoked media, as well as actual 

20 download and initialization times are recorded as they occur. These periods 
of time are inserted as time-outs in a created manual sequence. 

When a user is finished recording a manual sequence he or she 
invokes end function 391, thereby defining an end point to the instruction file 
which will be created for that particular sequence. The instruction file 

25 represented by files 1-4 in Fig. 22 is automatically created, in a preferred 
embodiment, as an executable file, and is stored on drive 393. When an 
instruction file is created, an associated icon represented herein by icons 
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379-385 is also created and installed as a shortcut within interface 365, in 
this case, accessible through window 375. 

In a preferred aspect of the invention, instruction files 1-4 and their 
associated icons 379-385 are all executables. That is to say that the user 
may launch a specific and automated navigation sequence by invoking either 
an instruction file or an associated icon. For example, user may simply 
navigate to a folder containing instruction files and invoke (click on) one of 
the instruction files. Upon doing so, interface 365 is launched automatically 
and an online connection is established. Once connected, the invoked 
instruction file will serve as a mini-template utilized by interface 365 for 
playing out the specified sequence. The same functionality may be provided 
through invocation of an icon wherein the icon is accessed and invoked 
before interface 365 is open or network connection is established. In this 
case, icons 379-385 may be available as shortcuts on a user desktop or in a 
system tray. In the example illustrated herein icons 379-385 launch 
automated navigation sequences after interface 365 is opened and network 
connection is established. 

The level of functionality provided to an automated navigation 
sequence depends in part on the capabilities of interface 365, capabilities of 
software provided as an API (Bowser plug-in), and capabilities associated 
with any extensions or programs interfaced with the API. According to a 
preferred embodiment navigation-related tasks exerting hyperlinks, 
performing downloads, populating form fields, and launching external 
applications, among other tasks, are supported in a completely automated 
navigation sequence. 

Fig. 23 is a block diagram illustrating automated navigation software 
395 according to an embodiment of the present invention. SW 395 is 
illustrated in this example as having two basic software layers. These are a 
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set-up layer 399 and a processing layer 397. SW 395 may be provided as a 
single application, which may be integrated with a standard desktop Bowser 
application. In another embodiment, SW 395 may be provided as a dual 
component comprising a browser plug-in and a desktop configuration tool 

Layer 399 is responsible for enabling a user to create custom 
instruction files, which serve as mini templates capable of providing a 
browser application with the proper instructions for performing and 
automated navigation sequence. Layer 397 is responsible for providing any 
extended functionality not already possessed by a standard browser 
application wherein such functions are used during automated navigation 
sequences. 

A recording module 407 is provided within layer 399 and adapted to 
enable a manual navigation sequence to be completely recorded with respect 
to browser and user activities. Recording module 407 integrates some 
provided functionality with functionality already possessed by a browser 
application in order to provide a recorded event that may be rendered as an 
executable file for repeating the manual session as a folly automated session. 
Several variables must be considered in order that a complete recording of a 
manual session may be converted into an executable file. For example, the 
exact network path must be recorded, HTML structures and feature- 
locations within those structures must be understood, locations and formats 
of interactive forms must be understood (form population), and exact user 
data-input as entered in a manual session must be retained. Therefore, 
recording module 407 has all of the appropriate interfaces to utilities generic 
to a browser application and to those utilities provided for enabling extended 
functionality. 

In one embodiment, a user may create his or her own instruction file 
for directing an automated navigation sequence. However, site logic and a 
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basic understanding of XML or other applicable machine-readable languages 
would be required of such an individual. In a preferred embodiment, actual 
manual implementation of a navigation sequence is recorded then converted 
automatically into a usable instruction file. 
5 A file-creation module 409 is provided within layer 399 and adapted 

to enable a complete rendition of a manual session to be converted into an 
executable instruction file. Module 409 may, in one embodiment, be 
enhanced such that by simply reading a manual session rendered by 
recording module 407, a machine-readable version (instruction file) of the 

10 session may be automatically generated. Instruction files may be generated 
in extensible-markup-language (XML), and in other known universal markup 
languages. A desktop browser then is enhanced to use the machine-readable 
file as an instruction template. A library of language characters may be 
provided as part of SW 395 for use in file generation. In some cases a 

15 proprietary version of XML or other machine-readable language is provided. 
Instruction files created by module 409 are, in a preferred 
embodiment, stored in a secure location in memory on a user's PC. In one 
embodiment such files may be saved in a removable memory drive as 
previously described. Immediately after file creation, a user may be 

20 prompted to enter a name for the created file and to configure a look for an 
icon associated with the created file. Such an icon, which is analogous to 
icon 366 of Fig. 21 a, may be automatically installed in an associated 
browser menu or toolbar, or may be provided on a user's desktop or in a 
lower system tray as previously described. 

25 An input module 41 1 provided within layer 399 and adapted to 

except additional data input from a user regarding options to add 
functionality to an automated routine wherein such functionality was not 
originally part of the routine. This particular feature provides a unique 
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opportunity for a user and for the provider of the software. For example, 
the provider of the software of the present invention maintains a complete 
data navigation, aggregation, and summary service on behalf of subscribed 
users by proxy. The service, which is described in many aspects in 
5 disclosure pertaining to cross-referenced applications, maintains a database 
for the purpose of profiling user information, site information, and so on. 

Through provision of a navigation-automation capability (SW 395) 
as a desktop consumable, which encompasses a scaled-down functionality 
from what is maintained and available at network level through subscription 

10 to the service, the service provider may create a new customer base that may 
be acclimated to and eventually driven to subscribe to a full proxy data- 
aggregation and summary service. The service provider may make some 
functionality immediately available through SW 395 wherein the added 
functionality is performed by proxy at the location of the service provider by 

15 virtue of fully automated navigation capabilities. In a case such as this, a 
user may be prompted through input module 41 1 to add such functionality 
into an automated sequence as desired. Added functionality may include 
summarizing, parsing, data-searching, solution-oriented computation, 
automated site registration, and other functions. 

20 In practice of the invention as described above, a user selecting 

certain functionality may input the required data parameters and insert the 
proxy routine at a specific point within the automated navigation routine 
specified by the instruction file. At a specific point during subsequent 
execution and commencing of an automated navigation sequence, the 

25 sequence itself will stall and a call will be placed from the user station 
executing the sequence to a proxy navigation subsystem maintained at 
network level by the service provider. During this transaction, the 
instruction file including the selected proxy routine or request is sent over 
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network lines to the navigation subsystem for execution and return of data. 
In one embodiment a user's navigator will stall until data is returned and 
presented to the user. In another embodiment the user's navigator may 
continue running its automated sequence and data return as a result of the 
5 proxy request may be transferred from the service provider to the requesting 
user in a call-back transaction. 

In another embodiment of the present invention a user, as part of an 
agreement with the service provider for enabling proxy functions to be 
performed during automated navigation sequences executed by the user, may 

10 allow the service provider access to a secure area of memory on a user's PC 
hard drive, or on a removable drive for the purpose of obtaining any data or 
information the service provider needs for satisfying a requested proxy 
routine inserted into an automated navigation sequence. In this aspect, a 
user's station becomes a data-source entity accessible under certain 

15 circumstances to the service provider. A database containing a plurality of 
such entities may be likened to the operating network itself. Therefore, the 
service provider may manage an entire customer base for limited proxy 
services without formal representation of that base using additional 
equipment and software that would otherwise be required. Moreover, such 

20 consumers acclimated to proxy functionality and addition of sites for 

servicing may be eventually eased into the service provider's main portal 
system as hardcore subscribers. 

Referring back to Fig. 23, a form population module 401 is provided 
within layer 397 and adapted with the functionality of automated form 

25 population using data from like form population performed manually during 
recording of a manual session. Module 401 may be enhanced to retrieve 
appropriate data from user files maintained at a user station. In this case it 
may be that sensitive user information is not maintained in an instruction file 
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but a pointer to that information, which is stored elsewhere, is included 
therein. In another embodiment of the present invention, it may be that 
sensitive information is included in an instruction file but in encrypted form 
until actual use. 

Form population module 401 represents an added functionality not 
available to a standard browser applications. It will be apparent to one with 
skill in the art that additional function modules representing other 
functionalities may be included within layer 397 without departing from the 
spirit and scope of the present invention. The inventor illustrates module 
401 and deems it exemplary of one such added capability. 

A mapping module 403 is provided within layer 397 and adapted to 
map not only network paths, but also locations within HTML structures or 
other data structures associated with data sources available on a network 
and accessible during performance of a preceding manual navigation 
sequence. In this example it may be assumed that module 403 is able to 
access and understand specific data structures representing the architectural 
templates of electronic information pages (Web pages) and functions 
embedded therein. Although module 403 is illustrated within processing 
layer 397, it actually functions in conjunction with module 407 illustrated 
within set-up layer 399. When a user is recording a manual navigation 
session for subsequent conversion into an instruction file, both recording and 
mapping may be considered processing functions. Therefore, processing 
layer 397 is active, in some respects, both during setup and execution of an 
automated navigation sequence. 

An execution module 405 is provided within layer 397 and adapted 
as an API for linking defined execution functions made a part of a navigation 
sequence to appropriate execution functions existing within a standard 
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desktop browser. Module 405 enables automated emulation of normally 
user-initiated functions. 

It will be apparent to one with skill in the art that there may be more 
functional modules included within SW 395 than are illustrated herein 
5 without departing from the spirit and scope of the present invention. 
Provision of additional functionality, not illustrated in this example, is 
dependent in part on practical considerations. For example, parsing and data 
summarizing capabilities may be reserved for proxy services because of the 
complex nature of the software required to perform such tasks. However, 

10 such functions or capabilities may be included herein in limited fashion. 

According to one embodiment of the present invention instruction 
files created by one user may be distributed to one or more peers practicing 
the present invention by virtue of SW 395. For example, an employer, 
instructor, or other individual in charge of a plurality of subordinates may 

15 create instruction files containing user names and passwords wherein such 
files are automatically distributed to a list of authorized subordinates upon 
creation. In this way the subordinates may experience a same automated 
navigation sequence including tasks performed. In some embodiments, this 
technique may be preferred over manually explaining navigation sequences 

20 to one or more individuals, or sending an end-page hyperlink. 

In one embodiment of the present invention and error-correction 
module may be included within processing layer 397. Such a module would 
be used to alert a user of a status change regarding an entity included in an 
automated navigation sequence. For example, if there are physical or 

25 structural changes or updates performed with respect to actual network 
entities represented in an automated navigation sequence, the navigation 
sequence would stall or fail. And error-correction module maybe enhanced 
for incorporating moderate updates and structural changes into instruction 
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files and enable re-execution of the automated sequences upon correction 
completion. In this case, the error correction module may command an 
additional browser window in order to access and determine current states 
and conditions and compare them with those existing in instruction files. In 
5 one aspect, a user may re-record a manual sequence to establish a current 
instruction file containing the updates. 

The method and apparatus of the present invention may be 
practiced via private individuals on the Internet, businesses operating on a 
WAN connected to the Internet, businesses operating via private WAN, and 
10 so on. There are many customizable situations. The present invention as 

taught herein and above should be afforded the broadest of scope. The spirit 
and scope of the present invention is limited only by the claims that follow. 
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What is claimed is: 

1 . A software application for creating and executing an automated browser 
5 navigation sequence comprising: 

a session recording module for recording parameters associated with 
a manual navigation sequence; 

a file creation module for converting data of a manual session into 
data comprising an executable sequence of instructions for conducting an 
10 automated navigation sequence; and 

an application-program-interface module for integrating a functional 
capability with the automated navigation sequence, characterized in that a 
completely automated, browser-navigation sequence performed by the 
browser application is enabled through execution of the executable 
15 instruction sequence created from the recorded parameters of the manual 
navigation sequence. 

2. The software application of claim 1, wherein the automated browser- 
navigation sequence is executed to run on a data-packet-network. 

20 

3. The software application of claim 2, wherein the data-packet-network is 
the Internet network. 

4. The software application of claim 3, wherein the file-creation module 
25 includes a function for creating an executable icon for launching the 

automated browser-navigation sequence. 
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5. The software application of claim 4, wherein the executable sequence of 
instructions are XML instructions. 

6. The software application of claim 5, wherein the automated-navigation 
5 sequence enables automation of one or more of form-population, data- 
downloading, media-interaction, data-searching, and hyper-linking. 

7. The software application of claim 6 ? wherein the application is 
implemented as a browser plug-in containing a user-configuration tool. 

10 

8. The software application of claim 6, wherein the application is 
implemented as a standalone program containing a user-configuration tool 

9. The software application of claim 1, wherein the automated navigation- 
sequence is created as a result of manual user programming as an alternative 

15 option to recording a manual sequence. 

10. The software application of claim 7, wherein the automated navigation- 
sequence includes an embedded request to one or more proxy services to be 
performed by a service provider operating on and accessible via the Internet 

20 network. 

1 1 . The software application of claim 10, wherein the embedded request is 
automatically sent to the service provider during execution and performance 
of an automated navigation sequence. 

25 

12. The software application of claim 11, wherein the embedded request is 
received by virtue of an opened communication channel established between 



-102- 

communicating navigation applications while the sending application is 
performing an automated navigation sequence. 

13. A method for creating an executable instruction file for performing an 
5 automated navigation sequence on a data-packet-network using a browser 

application comprising steps of; 

(a) invoking the browser application and connecting to the network; 

(b) invoking and activating a session-recording module for recording 
a manual navigation sequence; 

10 (c) performing a desired manual navigation sequence, the sequence 

recorded by the recording function; 

(d) activating a stop-record function to define the end of the manual 
sequence; and 

(e) converting the recorded manual sequence into the executable 
15 instruction enabling the automated sequence, the conversion performed by 

software; 

14. The method of claim 13 wherein in step (a), the data-packet-network is 
the Internet network. 

20 

15. The method of claim 14 wherein in step (e) 3 the software converting 
data from the recorded session into the executable instruction prompts a user 
to name the executable instruction and to name an icon created and 
associated with instruction. 

25 

16. The method of claim 15 wherein a step is added for prompting the user 
with a list of options to add proxy services to the executable instruction. 
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17. The method of claim 16, wherein the executable instruction is an XML 
template. 

18. The method of claim 17, wherein the executable instruction contains 
5 data personal to the user. 

19. The method of claim 18, wherein the personal data includes one or a 
combination of user names, passwords, credit card numbers, user location 
information, and Social Security information. 

10 

20. The method of claim 19, wherein the personal data remains encrypted 
until use. 

2 1 . The method of claim 1 8, wherein the personal data is stored in a secure 
15 location and accessed by virtue of a pointer to the information, the pointer 

embedded in the instruction file. 
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Abstract of the Disclosure 

A software application for enabling creation and execution of an 
5 automated browser navigation sequence is provided. The software 

application comprises a session recording module for recording parameters 
associated with a manual navigation sequence, a file creation module for 
converting data of a manual session into data comprising an executable 
sequence of instructions for conducting an automated navigation sequence, 

10 and an application-program-interface module for integrating a functional 
capability with the automated navigation sequence. The automated 
navigation sequence is characterized in that a completely automated 
browser-navigation sequence performed by the browser application is 
enabled through execution of the executable instruction sequence created 

15 from the recorded parameters of the manual navigation sequence. 
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DECLARATION AND POWER OF ATTORNEY FOR PATENT 

APPLICATION 

ATTORNEY DOCKET NO.P3938 



As a below named inventor, I hereby declare that: My residence, post office address and citizenship are as stated be 
low next to my name. I believe I am the original, first and sole inventor (if only one name is listed below) or an 
original, first and joint inventor (if plural names are listed below) of the subject matter which is claimed and for which 
a patent is sought on the invention entitled: Method and Apparatus for Providing Automation to an Internet 
Navigation Application 

the specification of which (check one) £3 is attached hereto. 

□ was filed on: 
□Application Serial No. 

□ and was amended on 

(If applicable) 

I hereby state that I have reviewed and understood the contents of the above-identified specification, including the 
claims, as amended by any amendment referred to above. I acknowledge the duty to disclose information which is 
material to the exarnination of this application in accordance with Title 37, Code of Federal Regulations, s 1 .56 (a), hi 
the case that the present application is a continuation-in-part application, I further acknowledge the duty to disclose 
material information as defined in 37 CFR s 1 .56(a) which became available between the filing date of the prior 
application and the filing date of the present application. I hereby claim foreign priority benefits under Title 35, United 
States Code si 1 9 of any foreign applications for patent or inventor's certificate listed below and have also identified 
below any foreign application for patent or inventor's certificate having a filing date before 
that of the application on which priority is claimed: 

Prior Foreign Applications) 

(Number) (Country) (Day/Month/Year Filed) 

(Number) (Country) (Day/Month/Year Filed) 

I hereby claim the benefit under Title 35, United States Codes, 120 and 1 19 of any United States application^) listed 
below and, insofar as the subject matter of each of the claims of this application is not disclosed in the prior United 
States application in the manner provided by the first paragraph of Title 35, United States Code, si 12, 1 acknowledge 
the duty to disclose material information as defined in Title 37, Code of Federal Regulations, si 56(a) which occurred 
between the filing date of the prior application and the national or PCT international filing date of this application. 



(Application Serial No.): 
(Application Serial No.): 
(Application Serial No.) 
(Application Serial No.) 
(Application Serial No.): 



09/629,492 (Filing Date): 07/31/2000 (Status): pending 

09/550.348 (Filing Date): 04/14/2000 (Status): pending 

09/532,647 (Filing Date): 03/22/2000 (Status): pending 

09/323.598 (Filing Date): 06/01/1999 (Status): pending 

09/208.740 (Filing Date): 12/08/1998 (Status): pending 



POWER OF ATTORNEY: As a named inventor, I hereby appoint the following attorney(s) and/or agent(s) to 
prosecute this application and transact all business in the Patent and Trademark Office connected therewith. 
(List name and registration number) 



Name:Donald R. Boys 



Reg. No. 35,074 



SEND CORRESPONDENCE TO: 
Donald R. Boys 
P.O. Box 187 
Aromas, CA 95004 



DIRECT TELEPHONE CALLS TO: 
Donald R. Boys (831) 726-1457 



I hereby declare that all statements made herein of my own knowledge are true and that all statements made on 
information and belief are believed to be true; and further that these statements were made with the knowledge that 
willful false statements and the like so made are punishable by fine or imprisonment, or both, under Section 1001 of 
Title 1 8 of the United States Code and that such willful false statements may jeopardize the validity of the application 
or any patent issued thereon. 



Full name of sole or first inventor: Sam Khavari 

1 st inventor's signature: Dated: 

Residence: 760 Bair Island Road #100. Redwood City. CA. 94063 Citizenship: US 
Post Office Address: Same 

Full name of 2nd joint inventor, if any: TimArmandpour 

2nd inventor's signature: Dated: 

Residence: 350 Meridian Dr., Redwood City, CA 94065 Citizenship: Iranian 
Post Office Address: Same 

Full name of 3rd joint inventor, if any: 

3rd inventor's signature: Dated: 

Residence: Citizenship: 

Post Office Address: 

Full name of 4th joint inventor, if any: 

4th inventor's signature: Dated: 

Residence: Citizenship: 

Post Office Address: 

Full name of 5th joint inventor, if any: 

5th inventor's signature: Dated: 

Residence: Citizenship: 

Post Office Address: 



Full name of 6th joint inventor, if any: 

6th inventor's signature: Dated: 

Residence: Citizenship: 

Post Office Address: 



Full name of 7th joint inventor, if any: 

7th inventor's signature: Dated: 

Residence: Citizenship: 

Post Office Address: 



Full name of 8th joint inventor, if any: 

8th inventor's signature: Dated: 

Residence: Citizenship: 

Post Office Address: 
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